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DATA BOOK 
This data book presents a complete 
technical description of the VLSI 
Technology, Inc. Application Specific 
Logic Products Division product line. 
Where devices have been fully charac- 
terized, either by VLSI Technology or by 
one of its partners, specific Information 
is presented in the form of data sheets. 
Information on partially characterized 
devices, devices currently under 
development, or devices that have their 
own Users Manuals containing data 
sheets, is in the form of product briefs. 
More complete data can be obtained on 
any device from the Logic Products 
Division Applications Department. 


in order to facilitate computer genera; 
tion of this data book, overbars (i.e. CS) 
have been replaced by a preceding 
minus sign (i.e. —CS) on all new or 
recently revised data sheets. Older data 
sheets will retain their overbars until a 
major revision is performed. 
GENERAL 
The primary business objective of VLSI 
Technology, lnc., (VLSI) is to provide 
systems designers with total applica- 
tion-specific integrated circuit (ASIC) 
solutions. To accomplish this, it has 
created a unique blend of expert design 
tools, leading-edge process technolo- 
gies, state-of-the-art fabrication 
facilities, and a wide range of products, 
including a variety of "catalog" devices. 


The Application Specific Logic Products 
Division of VLSI Technology is respon- 


VLSI TECHNOLOGY, mc. 


sible for the manufacture and marketing 
of a diverse logic-based product line 
that encompasses both innovative and 
proven, well established catalog 
devices. This line includes micropro- 
cessors and coprocessors, peripheral 
circuits, and products for data communi- 
cations and telecommunications 
applications. 


Unlike other suppliers of such devices, 
however, VLSI is also a recognized 
leader in ASlCs. As such, it not only 
possesses the design, process, and 
fabrication capabilities necessary to 
produce the highest-quality off-the-shelf 
components, but is also able to treat its 
logic products as an integral part of a 
complete solution. One of the primary 
vehicles for accomplishing this is the 
megacell; the functions represented by 
individual devices can be implemented 
as megacells in VLSl's software 
libraries and used for semicustom 
circuit design and functions developed 
as megacells for specific applications 
can be turned into catalog products. 


MEGACELLS 
The megacell is a relatively new 
concept in the world of IC and system 
design. As such ASIC companies as 
VLSI offer better tools for IC design, 
simulation, and testing, it becomes 
necessary for systems manufacturers to 
design custom lCs to keep up with their 
competition. Megacells help decrease 
design time by providing large building 
blocks that are equivalents of standard 
off-the-shelf products. By using 
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megacells and VLSl’s design tools, 
manufacturers can have a custom IC 
design capability without all of the 
normal custom development costs. 


The VLSI Technology family of meg- 
acells represents commonly used 
peripherals that are good candidates for 
integration as parts of customer-driven 
designs, which can be either customer- 
speciiic or market-specific. In cus- 
tomer-specilic designs, it is possible, for 
example, to combine these integration 
elements with other megacells and logic 
to become single-chip equivalents of 
computer systems that are already in 
production. This increased level of 
integration provides cost and space 
reduction that can keep the system 
designs competitive. In a market- 
specific design, upward-compatible 
enhancements that meet the needs of 
many customers can be added and the 
device offered as a new standard 
product. 


VLSl's megacells are designed to have 
a fixed height and variable widths, 
offering the best trade-off between 
unusable internal space and placement 
ease. As shown in Figure 1, they can 
be configured to make a very dense 
final design with a minimum of wasted 
silicon real estate. 


Of equal importance with the physical 
layout format of the cells is the structure 
of the interconnect bus. This bus must 
be generic enough to allow a wide 
variety of functions to be connected 


FIGURE 1. VLSI TECHNOLOGY MEGACELLS ARE OF A FIXED HEIGHT, WITH VARIABLE WIDTHS 
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uniformly and efficiently, and must be 
fast enough to not itself become a 
limiting factor as system performance 
increases. 


The internal structure of the bus created 
by VLSI for use with its megacells 
contains an m-bit data bus and an n-bit 
address bus, both of which are expand- 
able in width to accommodate changes 
in system requirements. The bus 
operates synchronously at a rate of 3 
million transfers a second, which is 
equivalent to the performance of a 10 
MHz 8086 or 12 MHz 68000 micropro- 
cessor. The bus definition allows for 
internal access times of 50 ns and cycle 
times in the 200 ns range. With standard 
pad drivers, external loads can be driven 
while supporting a 3 MHz bus frequency; 
faster speeds can be obtained by using 
faster pad drivers. To create a standard 
product from a megacell, an interface 
circuit is incorporated that exactly 
matches the slower timing of the external 
bus to the internal bus. 


MEGACELL-BASED DESIGN RATION- 
ALE 
There are many reasons why megacells 
make sense for new designs, including 
reduced board space, lower power, 
increased reliability and reduced design 
times. 


Typical applications that can benefit from 
the use of megacells are those that 
contain three or four LSI components 
and a handful of "glue" components. All 
of these components can be combined 
into a single component if the functions 
can be partitioned into logical groups 
with a reasonable number of I/O pins. In 
this type of application, the total pin 
count might be reduced from 300 pins for 
a discrete solution to less than 100 pins, 
and the circuit board area reduced from 
approximately 20 square inches to 2 
square inches. 


The power consumption of megacell 
designs can be very small in comparison 
with the HMOS designs they replace, 
since all of the VLSI Technology 
megacell family is implemented in high 
speed, low power, two-micron CMOS 
technology. In addition, because several 
functions can be put on one piece of 
silicon, the interconnect capacitance and 
inductances are minimized, thereby 
reducing the power to a fraction of what 
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was needed in previous designs. 


The reliability of a megacell-based 
design is typically better than the 
collection of discrete components it 
replaces because there are fewer pins, 
fewer bonding wires and lower total 
power consumption. In most systems, 
the largest contributor to reliability 
problems is IC pin connections, with 
such other factors as die temperature 
and die size being secondary. The more 
functional blocks that can be combined 
on a single piece of silicon, the fewer the 
number of interconnections that have to 
be bonded to package pins, resulting in 
higher overall reliability of the component 
and system using it. 


Since megacells can be used as high 
level building blocks, overall design 
times can be reduced significantly by 
taking existing designs using standard 
products and integrating additional 
support logic directly onto the chip. An 
example of this technique would be the 
integration of a VL68C45 CRT controller 
with a memory interface and video shift 
registers to form a single-chip video 
adapter. An additional option might be to 
include character ROMs or RAM arrays, 
although the addition of these commodity 
components is not always cost effective. 


CURRENT FAMILY OF MEGACELLS 
Megacells are designed by very carefully 
studying the data sheets and systems 
implementations of the original part 
vendors, but an important part of 
validating a megacell design is to subject 
it to many different hardware and 
software environments. Only after a part 
has been tested in several applications 
can a vendor feel confident that the 
megacell exactly emulates the original 
function, including all of the undocu- 
mented “features”. The VLSI Technol- 
ogy philosophy is to offer members of 
the megacell family as standard products 
as well as cells so that this validation can 
take place very quickly after the introduc- 
tion of the standard product. Since 
customer-specific design times typically 
take from two to four months, megacell 
designs can be started before the 
standard product validation has been 
done. This lead time allows customers 
to get a head start introducing designs. 
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DESIGNING A CIRCUIT USING 
MEGACELLS 
The design process is started by using a 
megacell schematic “icon” as part of the 
schematic entry of the user's design. 
Provided with the megacell icon is a data 
sheet detailing the internal timing 
requirements of the megacell. The 
designer works from this data sheet as if 
using an off-the-shelf standard product, 
except that the logic and timing of the 
bus are somewhat easier to use. 


USING VTltest DURING THE DESIGN 
PHASE 
When the schematic entry of the design 
is complete, the designer uses a test 
language assistance program (VTltest) 
to capture a set of simulation vectors that 
can be used to test the design after 
silicon has arrived. Once the designer is 
satisfied that the vector set is sufficient to 
cover all possible stuck faults, a final test 
program can be compiled through this 
program. The output from this program 
is a test program containing SETF 
statements that can be easily moved 
onto an industry-standard tester, such as 
a Sentry tester system. 


ADDITIONAL LOGIC FOR TEST 
SIMPLIFICATION 
In all cases, some additional logic will be 
necessary to facilitate testing the 
megacells. This additional logic consists 
of multiplexers on pins to allow all of the 
connections of the megacell to be 
accessed from the periphery of the 
circuit. This dictates that all designs be 
contained in packages having at least as 
many pins as the most pin-intensive 
megacell used internally. To enable the 
test mode, an illegal condition on the 
interface is often used, such as Read 
Strobe and Write Strobe being asserted 
together while the chip is selected. This 
would normally never occur in an 
application, so it is a safe combination to 
use. When enabled, the I/O pads of a 
specific megacell are connected to the 
I/O pins of the component, and the 
standard product test program run to 
verify the functionality of the core. 


USING VTltest SOFTWARE TO HELP 
CREATE TEST PROGRAMS 
VTltest is a software package that elimi- 
nates the need for the design engineer to 
be an expen in testers and testing. The 
designer works in a test language called 
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VLSI Test Language (VTL), which allows 
simultaneous development of the circuit 
design and test program, providing 
notification early in the design stages of 
when tester-specific details affect the 
testability of the design. Through the 
test language, designers can create a file 
describing the physical characteristics, 
timing, stimulus patterns and expected 
responses of a circuit under develop- 
ment (Figure 2). The remaining software 
translates the description into commands 
that run the simulation, verify the 
expected response, and store requested 
response values predicted from a 
simulator. Finally, VTltest generates a 
complete test program that includes all 
specifications for the timing generators, 
strobes, and registers, all pattern 
loading, requested dc parametric and 
summary test routines, and the test 
vectors needed to test the circuit 
functionality. 


Besides identifying tester limitations 
associated with the test program, the 
software suggests ways to work around 
them. In that way, design engineers can 
become familiar with tester limitations 
and make the optimum design-vs-testing 
trade-off. When the testability of a circuit 
becomes a problem, the design engineer 
can add additional circuitry to help out. 
Common practice is to break up long 
counter strings to reduce the number of 
states required to exercise each individ- 
ual stage. 


The test vectors generated by the 
software have a one-to-one correspon- 
dence with the vectors used during the 
simulation, so the information normally 
lost during post-processing is retained. 
Another benefit is that, since a tester is 
not needed to develop the test program 
and initially debug it, the test system is 
available for production time and work 
can be done during normal hours. 


To interface with specific testers, the 
software needs routines that contain 
tester-specific information. these 
routines also identify portions of the test 
or simulation language description that 
can not be executed by the tester, 
simplifying the task of making portable 
test software. Interface routines are 
currently written in Xidak’s Mainsail 
language for both VLSI's simulator and 
the Sentry Series 7, 10, and 20 testers. 


When defining an IC, designers can 
define the stimuli and the expected 
responses through the test language, 
creating modules that describe aspects 
of the circuit's functions or dc test 
conditions. The resulting circuit descrip- 
tion contains a complete set of 
operational parameters, all information 
necessary to create a data sheet is 
present. Since that information actually 
drives the simulator and develops the 
test program, it always remains up-to- 
date. 


FIGURE 2. THE STRUCTUE OF THE VLSI TECHNOLOGY TEST LANGUAGE MAKES TEST PROGRAM GENERATION 
SIMPLE AND STRAIGHT-FORWARD 


CORRECTION 
TEST LANGUAGE DESCRIPTION 


TESTER 
STIMULUS PATTERNS 
EXPECTED RESPONSES 
CHARACTERISTICS 


SIMULATOR 
LIMITATIONS 
TRANSLATION INTO SIMULATOR 
COMMANDS 


SIMULATION 


SIMULATION RESPONSES 


COMPARISON AND COMBINATION 


TESTER 
LIMITATIONS 
TRANSLATION INTO TEST PROGRAM 


PRODUCTION TEST PROGRAM 


3 


N VLSI TECHNOLOGY, mc. 
INTRODUCTION 


DEFINING THE TEST PROGRAM 
FLOW 
Several types of software modules are 
required to create a complete test 
description. Designers use the first 
module, MAIN, both to describe the 
overall flow of the test and to initialize the 
test software for execution. The con- 
tents of the MAIN module declare the 
duration of a test, select the required 
parameter modules, and specify their 
order of execution. The MAIN module 
partitions the testing into a number of 
steps that can be easily understood from 
a high level. 


The DURATION statement determines 
the length of the tester cycle, and 
normal-time selects the timing parameter 
module of that name. The WRITE 
commands place remarks in the test 
program file for documentation purposes. 


The physical characteristics of the IC 
and defined through the pin definition 
(PINDEF) module, which contains a 
declaration of the number of circuit pins 
and statements that the test software 
uses to identify pins during testing. 
Those pin definition statements also 
define pin type (input, output, bidirec- 
tional, power, etc.). In addition, the 
module may define the device type and 
state whether it is static or dynamic. 
Labels for each element of the pin list 
can specify such pin types as input, 
output, bidirectional, power ground, 
three-state, open-drain, open-source, or 
no connection. 


Minimum, nominal, and maximum timing 
parameters are defined in the TIMEP- 
ARAM module. Designers can test the 
circuit under different timing conditions 
by defining multiple modules and 
assigning each module its own identifier. 


An additional module, EDGETIME, 
creates transition edges using the 
parameters defined by TIMEPARAM. 
These edges determine when the 
stimulus values are placed on the input 
pins and when the response values are 
measured during each test cycle, 
indicating such timing points as when 
outputs should be sampled and when 
inputs should be changed. For example, 
to create a clock that remains low for 80 
ns, high for 100 ns, and repeats every 
200 ns would require the definition of 
four edges. The first edge would be at 0 
ns, the second at 80 ns, the third at 180 


ns, and the fourth at 200 ns. The last 
edge defines the period of the cycle and 
is also used for the duration declaration. 


For each test cycle, the CYCLE module 
describes the stimulus for input pins and 
the response for output pins. If parame- 
ter values are included within parenthe- 
ses in the module heading, a variety of 
values can be placed on the input pins. 
Each time the module is called, the 
appropriate values are passed to it. This 
module takes transition edges from the 
EDGETIME module and determines 
when to apply stimulus values to the I/O 
pins and when to measure outputs 
during each test cycle. CYCLE state- 
ments in the modules specify whether a 
specific pin is to be stimulated or 
measured. A transition edge at a pin 
may be specified by “@" time. If not 
specified, the stimulus values are placed 
on the pin at the beginning of the cycle 
and the responses are measured at the 
end of the cycle. 


With FUNCTIONTEST modules, the 
designer partitions the test into functional 
blocks or initialization procedures, 
particularly if the sections are to be used 
more than one. The first DCPARAM 
statement sets the minimum and 
maximum measurement values as well 
as the source that creates them (current 
or voltage). Defaults are provided if 
exact values have not been selected. An 
important attribute of this module is that 
some portions can be used more than 
once. These modules are executed 
when called by the MAIN routine or other 
FUNCTIONTEST routines. They may 
contain WHILE and other looping 
constructs to provide a means of 
conditionally executing statements. 


SIMULATION AND TEST PROGRAM 
GENERATION 
As the software generates the test 
program, it draws on the stimulus and 
response values to select each pin's 
timing generators and strobes on the 
basis of the value of the pin before the 
cycle starts, the number of transitions 
occurring on the pin during the cycle, 
and if the pin is to be an input or output 
during the cycle. 


The selection of mask register is 
determined by the state of the registers 
at the start of the cycle and the pins that 
have been activated during the cycle. 
The appropriate values are inserted into 


a test vector, which is stored in a vector 
file with the register set or enabling 
commands. Before storing the test 
vector, the software attempts to take 
advantage of any vector compaction 
capability of the tester. 


After the test language is used to create 
the modules, the resulting description file 
is loaded into VLS|test, which parsing, 
the software creates a data base from 
the physical characteristics described in 
the PINDEF module and from the 
identifiers used throughout the circuit 
description. After the program is 
properly compiled, testing may begin. 


The test language itself possesses all 
the power and flexibility needed to 
efficiently develop test programs. All 
variables and constants are 32-bit values 
that may be manipulated on a bit-by-bit 
basis by a variety of familiar operators, 
such as AND, OR, and XOR. Addition- 
ally, the language's looping constructs 
present a compact means of condition- 
ally executing a series of tests. 


COMPLETING THE DESIGN 
Test engineering effort is still required 
when using this process, but the time 
spent can be a matter of only a few 
weeks, rather than the several-week 
period traditionally associated with 
creating a test program for a new 
product. 


When simulation is complete and the 
design works satisfactorily, the layout 
process can begin. In most cases, 
designers are interested in minimizing 
design time and associated costs, so 
they pick standard cells for the additional 
blocks of logic that will surround the 
megacell cores. Cells are individually 
compiled, placed and routed to create 
blocks of logic until the entire non- 
megacell portion of the design is 
complete. For the best layout efficiency, 
the additional logic is either put into a 
block having the same height as a 
megacell, or it is put around the meg- 
acells to fill in the voids. When each 
portion of the design is completed, these 
blocks can be placed and interconnected 
using a tool call VLSICOMPOSE, which 
is a top level composition editor. This 
editor assists in interconnecting blocks of 
cells and optimizing both the placement 
and interconnection of cells. The overall 
goal of placing blocks to form the chip is 
to get the ratio of the X and Y dimen- 


4 


VLSI TECHNOLOGY mc. 
N 
. 
INTRODUCTION 


sions (the aspect ratio) as close to 1:1 as 
possible. The resulting square die gives 
the packaging engineer the most 
flexibility in package selection. 


When the entire layout process is 
complete, a netlist of interconnections is 
extracted from the physical data base to 
allow comparison of what was intended 
to be with what actually was imple- 
mented. Once the extraction is complete 
and the netlist comparison between 
schematic and layout is successful, the 
device can be resimulated in software 
with more accuracy, since values of 
expected capacitance are extracted 
along with the connectivity information. 


I 


Finally, the layout is checked for design 
rule violations using the design rule 
checker (DRC) program. 


When all of this has been successfully 
completed, the data base is sent to a 
design center, where the actual physical 
layout of the megacells is included in the 
data base. When everything checks out 
properly, a mask set is created and 
silicon is started. From this point, the 
fabrication time typically takes 8 weeks 
for the first pass prototypes. 


SUMMARY 
Megacells offer a way to quickly design 
chips that replace today's board level 
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function, while at the same time offering 
competitive costs, increased reliability, 
increased performance and reduced 
board space. The design process 
requires a wide range of design tools, 
including standard cells, cell compilers, 
simulators, routers, test program 
generators, and libraries of designs. 
VLSI Technology, Inc. specializes in 
offering these kinds of tools in addition to 
complete wafer services to provide a 
total solution to systems designers. 
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GENERAL 
VLSI Technology, lnc., Logic Products devices are available in a variety of plastic and ceramic packages - including flatpacks, 
chip carriers, and pin grid arrays - and in different temperature ranges. Specific information on the packages and temperature 
ranges for particular devices is coded into the part number portion of the order information included in each data sheet 


This information is organized as: 
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ORDERING - PACKAGING 


VL 
9999999 
bb 
p 
t 
e 
aa9999 


Temperature Code 


Package Type Code 


Bin Code (product-specific) 


Base Part Number (up to seven digits; may include dash character) 


SPECIAL NUMBER CODE 


ST9999 is a special test number. 


ENVIRONMENTAL GRADE CODE 


TEMPERATURE CODE 


PACKAGE TYPE CODE 


PART NUMBER EXAMPLE 


RC9999 is a ROM code number. 
SL9999 is a special lead number 
SM9999 is a special marketing number. 
SS9999 is a special specification number. 


Blank (no entry) -= information is not applicable. 


I = a 48-hour dynamic burn-in. 


C = 0°C to +70°C (commerical operating temperature range). 


I =- —40°C to +85°C (industrial operating temperature range). 
M = -55°C to +125°C (military operating temperature range). 


C = ceramic side-brazed dual in-line package (ceramic DIP). 
D = cerdip. 
F = flatpack. 
G = ceramic pin grid array (PGA). 
L = JEDEC type-B leadless chip carrier (LCC). 
P = plastic dual in-line package (plastic DIP). 
O =- plastic leaded chip carrier (PLCC). 


The package forms indicatedby the codes are illustrated in the 
outline drawings contained within this section. 


The part number VL68C45R-23PC SS0001 would indicate a 
CMOS revision R version of the 6845 CRT controller having a 
2 MHz bus clock and a 3 MHz character clock, housed in a 
plastic DIP, operating over the commercial temperature range, 
and tested to a special specification (#0001). 
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Special Number Code 


Environmental Grade Code 
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PACKAGE CONSIDERATIONS 
DUAL IN-LINE PACKAGES 
The dual in-line package (DIP) has 
been in high-volume production for 
nearly twenty years, and is estimated 
to have been the package of choice 
for over 80% of all integrated circuits 
shipped in 1985. Some 1986 usage 
estimates are as high as 18 billion 
units worldwide. Generally, devices 
in DlPs can be purchased in two 
types of ceramic (cerdip and side- 
brazed) and in the very-familiar 
molded plastic package. Over 85% 
of all DlPs, or over 12 billion, sold 
worldwide in 1985 were plastic. 
The ceramic side-brazed package is 
relatively expensive and is frequently 
imported. It has excellent mechani- 
cal characteristics, including the 
ability to survive extreme tempera- 
tures, salt water, and corrosive 
atmospheres. However, as the cost 
of the integrated circuit it houses 
becomes less and less expensive, 
the relative cost of the ceramic DIP 
becomes a major concern. In a large 
number of applications, this package 
is several times more expensive than 
the chip within it. As would be 
expected, this package is very 
popular in military electronics and in 
other potentially harsh mechanical 
environments. The side-brazed 
package, while representing less 
than 2% of all DIP packages ship- 
ped in 1985, represents a higher 
percentage of DIP revenue, due to 
its comparatively high average 
selling price (ASP). 
The cerdip is a “sandwich" of two 
ceramic parts that are joined 
together by a cement-like epoxy. The 
die itself is mounted on a lead 
frame, and enjoys many of the cost 
economies associated with this 
approach. The cerdip has some of 
the mechanical advantages of the 
side-brazed ceramic at a lower cost. 
The cerdip represented about 14% 
of all DIP shipments in 1985. 
The plastic DIP has been the cata- 
lyst for the computer revolution. The 
dramatic reduction in the cost of 
microprocessors, microprocessor 
peripherals, communications 
devices, and memories has been 
passed along to the manufacturers 
and the final users because plastic 
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packaging has remained extremely 
inexpensive. In addition, reliable 
automated 16-pin and 14-pin DIP 
insertion equipment has dramatically 
reduced manual "board stuffing" 
costs of DlPs. The plastic DIP itself 
is easy to manufacture. The die is 
mounted on a copper-alloy lead 
frame and the plastic material is 
molded around it. It is usually 
branded by a printing method with 
an epoxy-based ink but, recently, 
laser-scribing the number into the 
plastic body is gaining popularity, 
reducing costs even further. 


Mechanically, the DIP has proven to 
be an extremely utilitarian package 
in most applications. Its short, stiff 
leads on 2.54 mm (0.1 inch, or 
100 mil) centers allow reasonably 
easy insertion for both test and 
production by both manual and 
automatic techniques. While more 
expensive DlPs are placed in 
sockets, the overwhelming majority 
are soldered directly into the printed 
circuit board. The 64-pin DIP, the 
largest DIP in high-volume produc- 
tion, is used to house VLSl's VL2010 
and VL2044 Multiplier/Accumulators. 
DIP configurations with higher pin 
counts tend to exhibit unacceptable 
mechanical problems, such as 
extremely high insertion and extrac- 
tion forces. 
DlPs are available, in even-pin-count 
steps, in packages as low as two 
pins. A variation of the DIP that has 
gained some acceptance is the SIP, 
or single in-line package. The SIP, 
mounted lying on its edge, uses very 
little printed circuit board space and 
frequently contains a number of 
memory die in high-density memory 
applications. However, as desirable 
as the SIP may seem, it is not the 
major evolutionary path of the DIP. 
The SIP allows little air circulation for 
cooling, is hard to handle, and is not 
generally accepted as a standard. 
The DIP evolution lies in surface 
mounting the device. 


SMALL-OUTLINE 
INTEGRATED CIRCUITS 
The small-outline integrated circuit 
(SOIC) is a descendant of the DIP. 
Sometimes called the “Swiss” out- 
line integrated circuit in honor of its 


country of origin, this package solves 
many of the problems of the DIP. 
while retaining many of its advan- 
tages. The gull-wing lead rests on 
top of the printed circuit board rather 
than going through it. For most 
types, its leads are exactly half the 
length that the DlP’s are, and it 
maintains the same basic rectan- 
gular package aspect ratio of the 
DIP. This, however, becomes a 
disadvantage in high-pin-count 
applications. For more than 28 pins, 
many designers prefer the square 
aspect of the plastic leaded chip 
carrier (PLCC) to the SOIC. The 
small package mass of the SOIC 
does not allow the same thermal 
dissipation that can be expected in 
a standard DIP, which becomes a 
minor problem as more chips are 
made in the generally lower power 
consuming CMOS process. Most 
importantly, the SOIC consumes 
only about 30% of the real estate 
consumed by the standard DIP. It is 
estimated that nearly 1.5 billion 
SOIC units will be shipped in 1986. 


CHIP CARRIERS 
. 
Chip carriers have been around for 
several years in various forms, and 
are just now coming into widespread 
usage. Generally, the terminal 
spacing of chip carriers is 1.27 mm 
(50 mils), but several special types 
have 1.0 mm (40 mil) spacing for use 
by companies engaged in the pocket 
pager business. Some variations are 
available in 0.64 mm (25 mils) also. 
The ceramic versions of chip carriers 
have become very popular in military 
applications for the same reason the 
ceramic side-brazed DIP has:_their 
mechanical ruggedness. Frequently, 
ceramic leadless chip carriers 
(LCCs) are soldered in; others use 
connectors, while still others have 
their own leads and are inserted as 
a leaded device. Due to the 
dissimilar coefficient of expansion of 
materials (package alumina and 
printed circuit board fiberglass) and 
the lack of pins on the leadless 
versions to provide flexibility or 
compliance, the ceramic leadless 
chip carriers should be soldered to a 
material that has the same thermal 
expansion characteristics as they 
have. This has become very popular 


N 


in military applications where weight 
and space are at a premium and, 
generally, cost is not the primary 
consideration. 
The plastic leaded chip carrier 
(PLCC) has very quickly become the 
most popular of all the chip carriers. 
The PLCC represented about 61% 
of the chip carriers shipped in 1985 
(approximately 400 million units). 
Although there is debate on the 
issue of board space consumption, 
the PLCC and SOIC consume about 
the same amount of board space in 
the 24- to 28-pin configurations. In 
lower pin count applications, the 
SOIC seems to be more space- 
effective; when over 24 pins or so, 
the PLCC seems to have the edge in 
most applications. lnapplications 
over 28 pins, the PLCC is the surface- 
mount package of choice. Its square 
aspect ratio allows many chip 
placements that the highly rectan- 
gular package of the SOIC does not. 
In addition, there are rectangular 
PLCCs to accommodate such rec- 
tangular die, such as memories. 


CHIP-ON-BOARD MOUNTING 
The ultimate in low-cost chip 
mounting is achieved by the chip-on- 
board (COB) technology, in which no 
discrete package is actually 
employed. The die is soldered onto a 
copper pad on a printed circuit 
board. Bonding wires connect the 
die to smaller bonding pads around 
the die. The die and wires are then 
covered by a dollop of epoxy. This 
technique, while inexpensive, is not 


PIN COUNT DOMAIN 


I 
SOIC 
_ ‘ 
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generally accepted in industrial or 
business equipment. It has been 
extensively employed in video game 
cartridges, and seems to work quite 
well there. 


PIN GRID ARRAY 
The pin grid array (PGA), or “bed of 
nails," has only been around for ten 
years, but had a usage of about 
5 million in 1985, and its popularity 
is growing rapidly. This major 
package variation allows very high 
pin counts in relatively small spaces 
with excellent mechanical and 
thermal characteristics. The 149-pin 
VL82C389 Message Passing Co- 
processor (MPC) for Multibus@ ll 
systems is a prime example of PGA 
high-density trends. The major disad 
vantage of the PGA is its high cost. 
Virtually all of the 5 million PGA 
units shipped in 1985 were ceramic. 
Plastic pin grid arrays are well along 
in development, and will provide 
reliable, inexpensive packaging for 
the many high-pin-count ASIC, 
memory, and other circuits coming 
into wide usage. 


FLATPACK 
The flatpack holds less than 1% of 
the IC package market. True to its 
name, it is flat, small, and has flat 
leads usually in the same plane as 
the package body. It is generally 
harder to handle and test than the 
other package types, but provides a 
surface mounting alternative to the 
pin grid array in very-high-pin-count 
applications. It is usually surface 


mounted, “socketed, ” or suspended 
through a cut-out hole in the printed 
circuit board. 


SYSTEM CONSIDERATIONS 
In the extremely competitive com- 
puter market that now exists, every 
repetitive cost, no matter how small, 
comes under close scrutiny. Drilling 
a hole in a printed circuit board 
costs about_$0.001, a fairly small 
amount until it is multiplied by the 
thousands of holes that frequently 
occur in each board. This becomes a 
significant consideration at the 
system level. Even though re-tooling 
costs are high, many companies are 
converting (some at least partially) to 
surface-mounting equipment. Sur- 
face mounting allows more chips in 
a much smaller area, but not all 
functions are yet available in 
surface-mount packages. Some com- 
panies have solved this problem by 
designing both through-the-board 
and surface-mount devices onto the 
same board. Others continue to use 
the older technology until they can 
re-tool for 100% surface mount. 
Application-specific integrated 
circuits (ASlCs) and their support 
devices are requiring packages with 
ever-increasing pin counts. The pin 
count domain diagram graphically 
depicts the typical domain of pin 
counts for five basic package types. 
While there is a good deal of overlap, 
chip carriers and pin grid arrays will 
become the package of choice in 
future systems containing devices of 
high pin count. Since the PGA device 
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PIN GRID ARRAY 
I 
I 
I 
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@Multibus is a registered trademark of Intel Corporation. 
-_i 


does not support surface-mount 
technology, chip carriers or flatpack 
technology will have to be imple- 
mented as pin counts exceed 170 
using surface-mount systems. 


CONCLUSION 
There will be no panacea package 
that will exclude the use of all others 
in the future. While there are several 
criteria for the system designer, 


THERMAL CONSIDERATIONS 
The devices in this data book have 
undergone thorough evaluation and 
characterization to ensure their 
operation over the specified temper- 
ature ranges. While safety margins 
are used for all parametric tests over 
the temperature range, the designer 
should not exceed the temperature 
limits, even for extremely short 
intervals. The following notes are 
presented to ensure a reliable, long- 
lived system using VLSl’s products: 


3. 


4. 
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Table 1 examines some of the 
characteristics of packages that will 
probably occupy the overwhelming 
majority of printed circuit boards in 
the future. Leadless chip carriers will 
be especially popular in military and 
harsh industrial applications. The 
DIP, with many billions already in 
use, will not disappear, but its 
percentage of market will decrease 
steadily. Pin grid arrays will remain 


and increase in popularity as very 
large devices become more popular 
and plastic PGAs become readily 
available. Surface mounting is 
definitely a wave of the future for 
many systems. SOIC packaging will 
increase‘ rapidly for devices of 
28 terminals and under, while the 
mid-range and higher terminal count 
devices will be housed in PLCCs or 
flatpacks. 


1. While few designs subject devices to extreme cold, such conditions may 
cause the devices to operate outside of their normal specified ranges. 
Therefore, the minimum operating temperature specification must be 
observed as well as the maximum operating temperature. 


2. The ambient temperature (TA) specification refers to the air on the surface 
of the device. The printed circuit board design should be open enough to 
permit free air flow around the devices. 
Avoid layouts that place NMOS, HMOS, or CMOS devices near such heat 
sources as power regulators and devices requiring heat sinks. If the design 
demands such proximity, ensure that the specified temperature range is not 
exceeded. 
Ensure that the power supply voltage is within the specified range. Both low 
and high voltages beyond the specified limits may cause device 
overheating. 


TABLE 1. PACKAGE CHARACTERISTICS 


1 
JEDEC Leadless Chip Carriers 
DIP 


p_ 
— 
~ 
—— 
— 
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_. 
1- 
7 
1; 
5' 
5 
5 
*—1- 
Feature 
_‘ 
A 
J 
j 
C 
Ceramic 
Plastic 
SOIC 
j 
MPLCC 
A 
PGA 


Uses Socket or Connector 
Ti 
Yes 


> 
—777 
7 
7 
7 
I 
7777—— 
. 


I 
I 
Yes 
No 
Yes 
Yes 
No 
3 
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; 
Yes 


Directly Solderable 
I 
No 
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' 
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‘ 
No 
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40 
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7 
7 
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' 
Ti 
_ 
_ 
__ 
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__ 
_ 
777"" 
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64 
64 
l 
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Pin Spacing 
I 
I 
I 
I mm 
1 .27 
(mils) 
(50) 


77 
I 
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I 
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I 
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= 
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(50/40) 
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I 
l 
D 
Relative Cost (1 =j Most Costly) 
A 
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PACKAGE OUTLINES 


18-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP) 


.010 I7.574) 
.025 (I:.2s5) 
.250*(7.'112) 
T2i§0i(7f055) 
. . . . _ . . - - _7l_ 
. ,l 
|_ 
.900 (20.522) 
_‘ 
*.*550(22.0s2) 
.175 (4.445) 
_g1o Mm 
.105 (2.557) 
I-254) 
7 
I 
_I_ 
PLANE BASE 


SEATING PLANE 
055 (1 397) 
I-025 I-I535) 
_I I_-°°° I‘-52") 
I 
.175 (4.445) 
.012 (.005) 
j I. 
.055 (1.551) 
-°3° I-955) 
.125 (0.175) 
.005 (.200) " 
-0301-761) 
.021 (.500) 
.100 (2.54) 
.000 (7.52) 
:F1"5_(T5T) 
TYP 
TYP 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES( 
). 
2. TOLERANCE TO BE 1.005 (0.127). 
3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 
4. LEAD FINISH: GOLD PLATE OVER NICKEL. 


18-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 


.270 (5.555) 


.230 (5.842) 


P300 (20.320) 
.140 (0.555) 
REF 
-020 15-125) 
-12011045) 
'92I1I§I<'m) 
.200 (5.050) 
j-1'1-i 
J-I? 
MAX 


.015 (.051) 
$45 (3 683) 
.005 (.200) 
T‘ 
MIN 
_o6° 
E 
I__ _,l I_(,_5,4) 
.115 (2.921) 
3I*——~5° 
NQOI) 
.050“($24) 
TYP 
' 
TL)", 


<1 
.020 (.554) 
.100 (2.540) 
.015 (.051) 
"P 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE OR LEADITIN SOLDER. 
2. LEAD MATERIAL: ALLOY 42 OR COPPER. 
3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) 
MAX. AT EACH END. 
4. TOLERANCE TO BE 1.005 (0.127) UNLESS OTHERWISE NOTED. 
5. METRIC DIMENSIONS ARE IN PARENTHESES( 
). 
6. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE. 
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PACKAGE OUTLINES 
20-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (010) 


' ' 
~ 
_ 
_ ' ' _ -- 
.010 (7.574) 
.250 (7.112) 
I 


.325 (8.255) 
I. 
1.030 (26.162) 
390 (7335) 
_1g5 3557 
~ 
-5 
~ 
—-— 
°10(-354) 
MI,“ 
I 
.050 (24.502) 
Mm 


. 
- 
I 
I 
*—r 
H BASE PLANE 


I I 
$011150 
.055 (1.397) 
PLANE 
.025 (0.505) 
J L050 (1.524) 
_,75(4_“5) 
_m(_3°5) 
.055(1.551l 
'°°°"°°5’ 
~‘=5<°-"51 
-0051.200) 
7' 
—> 
.000 (.752) .021 (-533) 
.100 (2.540) 
.015 (.051) 
TYP 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
2. TOLERANCE TO BE 1 .005 (0.127). 
3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 
4. LEAD FINISH: GOLD PLATE OVER NICKEL. 


20-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 


.270 (5.555) 
.200 (5.542) 


.000 (22.550) 
I<—- 
REF 
—~I 
.020 (5.125) 
.200 (5.050) 
1.050 (25.570) 
“I” 
MAX 
‘""—— 
MAX 
.Z’ 
.155(0.907) 
jnzs (0.175) 


-015$-P381) 
i 
E 
E 
H 
G 
H 
g 
II 
PLANE 
.005(0.200) 
9°- 


H 
.050(1.524) 
_. I._ 7. 
Typ 
;11Q_<i§§§). 


-. 
i 


075 (1 905) 
I 
120 (3 048) 
350(1) 390) 
MAX 
.020 (0.554) 
.100 (2.540) 
7"’ 
.015 (0.051) 
TYP 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 
. LEAD MATERIAL: ALLOY 42 OR COPPER. 
2 
3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR. WHICH IS .010 (0.254) MAX 
AT EACH END. 
4. TOLERANCE TO as 4 .005(0.127). 
5. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
5. PIN 1 moex MARK MAY VARY IN SIZE AND SHAPE. 
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PACKAGE OUTLINES 
24-PIN 0.0" WIDE PLASTIC DUAL IN-LINE PACKAGE ("SKINNY" DIP) 


ORDERING - PACKAGING 


.250 (7.112) 
.020 (5.125) 
.240 (5.055) 
-80017-620) 


__ 
1.270*(32.258) W 
LI-i1.100(27.940) REFZ>Il 


-200 5.080 
1.230 (31.242) 
_155 (3337) 


.150 (0.510) 
-12513-175) 
EL.‘ 


BASE 
-L 
PLANE 
15° 


SEATING 
.070 (1.778) 
PLANE 
.0150-081) 
_o6°(,_524) 
| L .140(0.555) 
I“ 
.120 0.045 
.055(2.159) 
"P 
-10012-540) 
I 
I 
_Q4Q (1315) 
> 
i .023 (0.584) 
TYP 
.015(0.051) 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 
2. LEAD MATERIAL: ALLOY 42 OR COPPER. 
3. ALL METRIC DIMENSIONS ARE'IN PARENTHESES. 
4. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS 
MAX. AT EACH END. 
5. TOLERANCE TO BE ;t .005 (0.127). 
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.300 (7.620) 
TYP 
.155 (3.937) 
Ti‘ 
.125 (3.175) 


.015 (0.381) 


( 
( 
.008 (0.203) 


.420 (10.555) 
MAX 


.010 (0.254) 
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PACKAGE OUTLINES 


24-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 


LL-LQLQLLL-QLL 


CJFHDEHRHVGE-IPANDFLAISHVCE 


' 
.560 (14.224) 
.520 (13208) 
I“‘ZJ&$J"j 
MAX 
.185 (4.191) 


.1 35 (3.429) 


1 .280 (32.512) 
.620 (15.748) 
<- 
MAX 
' | .01'5‘(03051) 
) 
MAx 
‘I 


—I 
SEATING 
1°50 
.015 
.200(5.050) 
$ 
""’ 
-00810-203) 
MAx 
.050 (1.524) 
-l_‘_9_Q-_§§§l 
.120 
.04 
_ 
<——> 
. 


TYP 
.015 (0.051) 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 


.\ 
2. LEAD MATERIAL: ALLOY 42 OR COPPER. 
‘ 


TYP 
I3 
BI 
550 (15 510) 
—-—> 
<— 
—> 
<- 
100 (2.540) 
.020 (0.554) 
TYP 


3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR, WHICH IS .010 (0.254) MAX 
AT EACH END. 
4. TOLERANCE TO BE 3 .005 (0.127). 
5. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
6. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE. 


28-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP) 


25 21 
15 15 
— 
— 
— 
_ 
— 
- 
__ 
Q 
-Q 
_._ 
_ 
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.610(15.494) 
i8-0L(14.732) 


__ 
_ 
_ 
_ _ 
Q 
_ 
1014 
1-43006-322) 
, 
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Mm 
-600($-224°) 
_L 
_F eAsE PLANE 
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I 
PEAIIIEIG 
.020(.s05) 
L_ 
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‘"5HIMS) 
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_,II_'°°°‘"°°5’ 
I_ 
.12510.115) 
-°°°l-2°“) 
-°3°l-761’) 
.020(.554) 
.1o0(2.540) 
.015(.051) 
TYP 


NOTES: UNLESS OTHERWISE sPEc1r-1E0. 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
2. TOLERANCE TO 5E 4 .005 (0.127). 
0. LEAo MATERIAL: ALLOY 42 (on EQUIVALENT). 
4. LEAo FNISH: GOLD PLATE ovER NICKEL. 
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PACKAGE OUTLINES 
28-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 


LLLLULLLQLLLLLL 


D 
.550 (1i._23_4_) 
.520 (10.205) 


‘“iF'_Q_ 9 
Q 
Q Q Q Q 
w_'5'__Q""q_I_I0'_'$‘ 
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I I 
1.000 (00.020) 
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REF 
.165 (4.191) 
.135 (3.429) 
1.410 (07005) 
-520115.145) 
MAX 
'|.015(0.051) 
3‘ 
MAx 
T) 
|||||| |||||||| 
§f§;'§° 
/100 
-4.2502» 
.200 (5.050) 
II 
w 
.005 (0.208) 
MAX 
_()5() (1 _$24) 
'.I£Q;6i9I 
, 
TYP 
-12° <3-°‘°l 
.550-(15510) 
.100 (2.540) 
020110.554) 
TYP *—l 
"P 
155531?) 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE OR LEADITIN SOLDER. 
2. LEAD MATERIAL: ALLOY 42 OR COPPER. 
3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR WHICH IS .010(0.254) MAX. AT EACH END. 
4. TOLERANCE TO BE i .005 (0.127) UNLESS OTHERWISE NOTED. 
5. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
6. PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE. 


28-PIN PLASTIC LEADED CHIP CARRIER (PLCC) 


_>* I: .045 (1.143) 


I 
.450 (11.554) 
MAx 
I3 


.455 (12510) 
MAx 
I3 


4° All $'°5f_\ 
.025(0.111) 


.075 (1.905) 
MAX 


_ 20 
_|1-,0; 
<-.002 (0.512) 
-'55“-59°) 
0 MIX 
I 
.050(1.210)__IL 
MAx 
TYP 
.021 (.533) 
.013 (.330) 


.049 (1.244) 


NOTES: ur1LE.ss ommwrsa SPECIFIED. 
1. TOLERANCE TO BE 1 .005 (0.127). 
2. LEAOPRANE MATERIAL: coPPER. 
0 LEAo FNSH: MATTE TN PLATE OR soLoER on 
4. SPACING To BE MAnTA|\Eo eErwE!-J1 FORBED LEAo AND MOLDED PLASTIC ALONG 
FULL LENGTH OF LEAo. 
5. MOLDED PLAsTIco1MENsIoNooesNcrrr1cLuoEsnEFLAsH BURR,WHICHIS.010 
(0254) MAx ON FOUR SIDES. 
5. ALL MErR|c DIMENSIONS ARE 1N PARENTHEsEs. 


VLSI TECHNOLOGY, INC 


PACKAGE OUTLINES 


‘W 


_ 
. 
|.' 


) 
-. 
"- 


Im A -I 
ll? 
I 
.11‘ 
- 
,. 
. 
. 
. 
1__- 
‘-_\. 


'.'=-.4‘)-. 
ORDERING - PACKAGING 


‘ 
__.'__' 


40-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP) 


40 
21 


' ' _ ' “ ' ' ' ' ' ' ' ' ' ' ' ' ' 


2.030 131.552) 


_510115,49.1) 
.625 115.875) 
.530 11 4.132) 
595115.113) 
J 


J90 (M26) 
1.9ao 150.292) 


.035 12.159) 


_I_ 


.010 11.773) 


1955 3:55 
A 
.030 1.162) 
_oz3 
.o1s1.3a1) 


NOTES: UNLESS OTHERWISE SPECIFIED. 


-°‘°(-254) 
.500 115.2-1o)_, 
MIN. 
Typ 
_L 
:1-_ BASE PLANE 


SEATING 
PLANE 
.02o1.soa_)l L_ 
Lmi 
11514 445) 


I 
‘I 
, 
1°38 (365) 
.1oo12.s4o) 
.125 132175) 
-°'2I-3°5I 
1.584) 
TYP 
.o0a 1.203) 


1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
2. TOLERANCE TO BE 3 .005 (0.127). 
3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 
4. LEAD FINISH: GOLD PLATE OVER NICKEL. 


40-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 


LLQLLLLLALLLILIQLLLLLL 


Q Q Q"-F'Q “Q—'Q_Q Q 
Q Q Q 
Q 
Q 
'I7"'Q 
QMQMQHQ 


.560 (14224) 
.520 (13208) 


I--li_1.9oo 143.230)REF} 


.165 (4.191) 


.135 (3.429) 


1 
1 
2° 
8 2 MAX 
.s2o11s.14a) 
I‘ 
' 5°52‘ 3 I 
'|.o1s10.3a1) 
“T 
MAX 
T‘ 
'1'1'1'1'1'1'1'1'1'1'1'1'1"1'1'1'1'1'1'1'”%...~1G 
,. 


__> 
é 
.100 12.540) 
.023 10.534) 
TYP 
.o1s1o.3a1) 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAO mass: MATTE TIN PLATE on LEAD/TIN SOLDER. 
. LEAo MATERIAL: ALLOY 42 on COPPER. 
. PACKAGE LENGTH 0oEs NOT INCLUDE END FLASH aura 
AT EACH END. 
. TOLERANCE TO BE 1 .oos1o.121). 
5. ALL METRIC omsnsrous ARE IN PARENTHESES. 
s. PIN 1 INDEX MARK MAY VARY m s1zE AND SHAPE. 


2 
3 


4 


TYP 
( 
°( °‘°I 
I__ eso11s 510) 
.030 12.236) 
TYP 
MAX 


R, WHICH IS .010 (0.254) MAX 


VLSI TECHNOLOGXZ 11\1c. 


PACKAGE ounmes 


44-PIN PLASTIC LEADED CHIP CARRIER (PLCC) 


.01511.005) 
\ 
MAx 
1 
ii... 


ORDERING - PACKAGING 


PIN 1 INDEX 
MAY VARY IN 
SIZE AND 
LOCATION 


, 
.595 111.553) 
MAx 


.02a10.111) 


"Tl 
<-.045 (1.143) 


I 
I 


.880 (18.784) 
MAX 


/Ir} ALL SIDES 
'— 
‘O49 ("WI 
TI 


.0201I>.152) 
--I 
_. 
<-.03210.a12) 
-1°5(4-699) 
MAx 
.05011.210) 
MAx 


TYP 
i I<— .025 (0.835) 
.015 (0.381) 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1 . TOLERANCE TO BE 1 .005 (0.127). 
2. LEADFRAME MATERIAL: COPPER. 
3. LEAD FINISH: MATTE TIN PLATE OR SOLDER DIP. 
4. SPACING TO BE MAINTAINED BETWEEN FORMED LEAD AND MOLDED PLASTIC ALONG 
FULL LENGTH OF LEAD. 
5. MOLDED PLASTIC DIMENSION DOES NOT INCLUDE SIDE FLASH BURR, WHICH IS .010 
(0.254) MAX ON FOUR SIDES. 
6. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 


40-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP) 


4 _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 9 


510115.494) 
500114.132) 


' ' ” ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' " ' " 


2 430 (61 722) 


235° I°°"52I 
’.0101.25-1) 
525115.515) 
.1s014.a25)MAx 
MIN 
"'* |595(15_, 13,1" 
—I- 
1 
__I 
BASE 13LAuE 


.020 .500 
- 
I 
I 
I 
.050(1.524) 
.11514.445) 
. 
-0121-305) 
I 
-~§ 
-0-— 
—> 
--> 
Q-— 
\ 
--pl)-Q-_. 
.05511.551) 
.101¥$i540) 
-°38(- 
) __ ___ 
.12513.115) 
-0081103) 
.030(.752) 
_°23(_584) 


.0151.3a1) 
1""-°°° T"'—* 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
2. TOLERANCE TO BE 1 .005 (0.127). 
3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 
4. LEAD FINISH: GOLD PLATE OVER NICKEL. 


VLSI TECHNOLOGY, mc. 
ORDERING - PACKAGING 


PACKAGE OUTLINES 
48-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 


LL1LLLLLLLQLLL1i|L£1LLuQLL 


.570 (14.478) 
. 
.530 (13.462) 


‘"Q_QQQ"Q’QQQQQQQQQQ_QQ'_Q_QQQQ§Q i 


2 
1 
2300150420) 
I 
_ 
_| 
REF 
£514.445) 
.145(3.683)‘ 
W 
Hf 
_z_451)1s2_231)) 
H 
W 
‘_-62°05-748) 


| 
MAx 
'].01510.301) 
MAX 
Tl 
MIN 
. 
ITITITITITITITITITITITITITIIIIIIITIIITI 
SEATING 
/105° 
.g1510.301) 


.20015.000) 
PLANE 
I 
50° 
"T 
'°°8I°'2°3I 
M 
‘ 
.00015.24 
I 
-14°(3-65?) 


.100 12.540) 
.023 10.504) 
.015 11.905) 


AX 
I 
0) 
___ 


' 
TYP 
I20 (3-043) 
1‘_.650 (16.510) 


TYP 
.010 10.254) 
MAx 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE OR LEAD/TIN SOLDER. 
2. LEAD MATERIAL: ALLOY 42 OR COPPER. 
3. PACKAGE LENGTH DOES NOT INCLUDE END FLASH BURR. WHICH IS .010 (0.254) MAX 
AT EACH END. 
4. TOLERANCE TO BE 3 .005 (0.127) UNLESS OTHERWISE NOTED. 
5. METRIC DIMENSIONS ARE IN PARENTHESES. 
6. 
PIN 1 INDEX MARK MAY VARY IN SIZE AND SHAPE. 


64-PIN CERAMIC SIDE-BRAZED DUAL IN-LINE PACKAGE (DIP) 


6 3_ 
_ 
_ 
_ 
_ _ 
_ _ 
_ 
_ 
_ 
_ _ 
_ 
_ 
_ _ 
_ _ _ _ 
_ _ 
_ _ 
_ 
_ 3 3 
‘ 


914123.210) 
. 
.004122.454) 


1 
I 
hi-M-iii 


_--Q-_——-___————-—¢_.___—__1_..q¢__,¢ 
ii 
1 
2 3 
82 
3132 
r__12011 
. 00)__‘ 
3.240102.290)_ 
U “Ax 
_ 
‘*"“*i‘— 
MAx 
A 
" 
930123.022) 
.19014.020)MAx 
"I‘i(f5‘I 
[‘;_g00m_a51))"‘ 


I .I_ 
I BASE PLANE R 
SEATING 
.o1011.110) 
PLANE 
.020(.505I 
L__ 
_Q5Q(1_524) 
_175(4_445) 
.012(.305) 


.00511.0s1) 
__ ___ -0381-965) 
.12s13.115) 
-°°°I-2°?" 
-°3°(~7°2I 
.0231.s04) 
.0151.301) 
;_T_ 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
2. TOLERANCE TO BE -_t .005 (0.127). 
3. LEAD MATERIAL: ALLOY 42 (OR EQUIVALENT). 
4. LEAD FINISH: GOLD PLATE OVER NICKEL. 


VLSI TECHNOLOGY, mc. 
ORDERING - PACKAGING 


PACKAGE OUTLINES 


64-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP) 
bbbbb 


D 
.020 120.020) 
.1001'19.012) 


QT.'7'9.QQTPQVQQQTQTTQTTQQPTQQQ 
Q 
/ 
. 
_ 
I 
.. 
3.100 110.140) 
. 
PIN 1 
|‘ 
REF 
____!__ 


.19514.953) 
.T05'(4.19T) 
|_ 
2 
3.230102.042)- 
,| 
__-920~(5\3i368)_, 
MAX 
.0151.341) 
1" 
-1 1._.........,... 
......,... 
~—~15°11:*=°>—~ 
120 13 040) 
.023 1.500) 
.0-15 (381) 
.00511.0s1)MAx 


NOTES: uNLEss OTHERWISE SPECIFIED. 
1. LEAD FINISH: MATTE TIN PLATE 0R LEAD/TIN SOLDER. 
2. LEAD MATERIAL: ALLOY 42 0R coPPER. 
3. PACKAGE LENGTH DOES NoT INCLUDE EN0 FLASH 0uRR. wmcu 1s .010 10.254) MAX 
AT EACH END. 
4. ToLERANcE T0 BE 1 .005 10.121). 
5. METRIC DIMENSIONS ARE IN PARENTHESES. 
0. PIN 1 INDEX MARK MAY VARY IN SIZE AN0 SHAPE. 


68-PIN PLASTIC LEADED CHIP CARRIER (PLCC) 


—-I ‘+045 (1.143) 


I 
I 
I 


PIN 
1 INDEX 
MAY VARY IN 
1 
SIZE AND 
LOCATION 


11111111 


.4 O 
. 


1IIIIIIiIIIIII§Z 


in O’!0 24.304 
O 
11.IAx 
I 


"-II-11111111111 
' 
.995 125.213)_. 
1 
_ 
_ 
(‘"9 
MAx 
4° ALL SIDES 
)\ 
.0201.111)_.* l._ 
.04911.244) 
/' 
.01511.90s) 
1 
‘ 


Q§_I-FIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIU 


0301.102) 
‘I 
I~.0s011.210) 
-.1 
.0321.012) 
.10514.099) 
MAx 
.025 1.035) 
MAX 
.0151.3'0T) *’\ 5" 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. 
TOLERANCE TO BE 1 .005 (0.127). 
2. LEADFRAME MATERIAL: COPPER. 
3. LEAD FINISH: MATTE TIN PLATE OR SOLDER DIP. 
4. SPACING TO BE MAINTAINED BETWEEN FORMED LEAD AND MOLDED PLASTIC ALONG 
FULL LENGTH OF LEAD. 
' 
5. MOLDED PLASTIC DIMENSION DOES NOT INCLUDE SIDE FLASH BURR. WHICH IS .010 
(0.254) MAX ON FOUR SIDES. 
6. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
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VLSI TECHNOLOGY. INC. 
ORDERING - PACKAGING 


PACKAGE OUTLINES 
68-PIN LEADLESS CHIP CARRIER 11.00) 


—-—-I—— .05011.210) TvP 
Illllllllllllllll 
___3p|_5 


SEATING PLANE; 
ELECTRICALLY 
ACTIVE PLANE 
°"TH1$ SIDE 
i_I__ .039 10.991) 
——§-—- ._j03310.0_30) 


PIN 1 


I 
In 
‘ 
||||||||||||||||11 
;'::I.‘|;g;°)N;;§c°RNER 


1 


A 
.00312.100) 
__I 
I__ 
1 
I 
I 
':I 
T" .009 11.153) 
.050 11.210) 
.053 12.302) 
4-‘g 1'2? 
TYP 
.01111.955) 
- 
I - 
I 
LEA01oNLv 


NOTES: UNLESS OTHERWISE SPECIFIED. 
1. TOLERANCE: :t .005 (0.127). 
2. ALL EXPOSED METALLIZED AREAS: GOLD-PLATED (60 MICROINCHES MIN. 
_ 
___ 
_ 
_ 
____ 
_ 
. 
THICKNESS) OVER NICKEL (50 MICROINCHES MIN., 350 MICROINCHES MAX.) 
OVER REFRACTORY METALLIZATION. 
I 
3. MATERIAL: AL;0; 
1 
__ 
_ 
4. LID SEAL: 0oL0mN EUTECTIC. 
I 
5. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
METRIC DIMENSIONS ARE IN 
"I 
1110001005. 
<50§.11w=> 
-94511445111 
5. 000:0 TYPEBPACKAGE. 
| 
I 
.505 114.0591 
-940121010) 


|_____| 
‘ 


. 
I 
..... 
I_ 
000120.320) 
_ 
H 
_I 
* 
A 
(PCS " 
A 


. 
-95594151?) 
_ 
.940 123.010) 


VLSI TECHNOLOGY, mc. 
ORDERING - PACKAGING 


PACKAGE OUTLINES 


04-P1N PLASTIC LEADED CHIP CARRIER (PLCC) 


—-‘ 
I:.04511.143) 


PIN 1 INDEX 
MAY VARY IN 
SIZE AND 
LOCATION 


.100129.454) 
MAx 


, 
_ 
1.195 (30.353) _ 
(_ 
__ 
MAX 


4° ALL SIDES 
/II_\ 
.0201.111)-.1 I._ 
.04911.244) 
.01511.905) 
MAx 
IFIIIIIIIIIIIIIIIIIIIIIIIIIIIII' 
IIIIIIIIIIJ 


.03010.102) 
->I 
I--°5° (I-17°) 
. 
.032 1.012) 
.105 14.099) 
MAX 
TYP 
.025 1.035) 
MAx 
._...i...._->-4- 
.0151.301) 
M 


uNLEss OTHERWISE SPECIFIED: 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
METR1c DIMENSIONS ARE 1N M1LL1METERs. 
2. TOLERANCE To 01: 100510.121). 
3. LEADFRAME MATERIAL: COPPER. 
4. LEAD FINISH: MATTE TIN PLATE on SOLDER DIP. 
5. sPAc1NG To BE MA1NTA1NE0 BETWEEN 1=oRME0 LEAD AND MOLDED PLASTIC 
ALoNG FULL LENGTH o1= LEAD. 
0. MOLDED PLASTIC 01MENs1oN DOES NoT INCLUDE 5105 FLASH 0uRR. wmcn 1s 
.01010.254) MAx. 0N 1=ouR s10Es. 



VLSI TECHNOLOGY. mc. 
ORDERING - PACKAGING 


PACKAGE OUTLINES 


84-PIN LEADLESS CHIP cARR1ER (LCC) 



>- 


I‘ 
1.010125.054) 
.099125.140) 
"“' PI" I 
4 PLS 


.039 (.991) 
.033 1.030) 
I 
TYP 
_I_ 
» 
I 


I 
I 
IIIIIIIIIIIIIIIIIIIII 
I 
.0s011.210) 
_ 
-676117-170) 
TYP 
___.05011.210) 
.0301.102) x 45° 
* 
504110.055): 
I 
I T 
077 (1 956) 
I 
3PLs 
CHAMFER INDEX c0RNER"I 


.01511.905) 


' 
bi’ 
M 


1 _1.101129.409) 
*"‘""“"—_1)¢;3 
11,500) 
-095 (1-413) 
1.139 (28.930) 


. 
. 
. 
I 
I 
LEAD 1 ONLY 
IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII 
SEATING PLANE 
ELECTRICALLY ACTIVE PLANE ON THIS SIDE 
I 
I 
.000 11.010) 
UNLESS OTHERWISE SPECIFIED: 
“"“'"""‘,054 
(1,375 
1. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
METRIC DIMENSIONS ARE IN MILLIMETERS. 
2. TOLERANCE TO BE 1.005 (0.127). 
3. ALL EXPOSED METALLIZED AREAS SHALL BE GOLD-PLATED (60 MICROINCHES 
MIN. THICKNESS) OVER NICKEL (50 MICROINCHES MIN., 350 MICROINCHES 
MAX.) OVER REFRACTORY METALLIZATION. 
4. 
AI1U;|. 
5. JEDEC TYPE B PACKAGE. 


I 


22 


VLSI TECHNOLOGY, mc. 


PACKAGE OUTLINES 
100-PIN PLASTIC FLATPACK (CJOFP) 


0.195 120.20) 
I 
~ 
.§-n---- 
- 
_-— 
-—— 
—;-—— 
— 
r 
0.748 (19.00) 


0.557 (14.15) 
I 
‘ 
|._q_..._,_. 
_ 
. 
_....,;_ 
_ 
, _-.~ 
E 
9, 
I 
0.545 (13.85) 


I 


. ...._-_-_--- 1»; 
/PIN100 
llllllllllllllllllll 
. 


ORDERING - PACKAGING 


_._.__ 
I 


T 
E.‘ 
. 
1 


0.793 (20.15) 
1.031 (26.20) 
0.102 119.05) 
0-984 (25-00) 


2 
.- 
_ 
I. 
2 


0.023 (0.58) TYP 


|-- 
--4 


\. 


0.120 13.05) 
0.10012.55) 
-02610-65) 


\ 


_ 
_ 


I 
______i_>_ 
‘ 
_>‘ 
0.033 (O.83)TYP 
\\ 
-°94 (2-4°) 
* 


0.008 (0.20) 
I ii 
°-°°5 <°~'°> 
- - 
- - 
- - 
- - 
- - 
- - — 
SEE DETAIL 
I 
‘ 
_/IlllilllllililllllililllllIIIIIIIIIIIIIIL 
I 
\ 
Y 
H; 
L 
1 
1 


SEATING PLANE 


0.100 (2.55) 


NOTES: UNLESS OTHERWISE SPECIFIED 
1. THE CJOFP ARE CURRENTLY USED ONLY FOR PROTOTYPE BUILDS. 
2. ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
3. CJOFP ARE EPOXY DIE ATTACHED AND EPOXY SEALED. 
4. LEADFRAME: ALLOY 42 
DIE ATTACH MATERIAL: HITACHI CHE EN-4000, KASEI EPINAR 4110 
MOLD COMPOUND: SUMITOMO 6300. KASEI CEL 4000 


001010.25) 
__-3- ..__._ 
0-00412-10) 


0.016 (0.40) 
0.008 (0.20) 


0.04311.10) 


~ 
T 
“T” 
0.130 13.30) 
5° TYP 


VLSI TECHNOLOGY. INC. 


PACKAGE OUTLINES 


149-PIN cERAM1c PIN GRID ARRAY (PGA) 


i 
I 
P_J_ 
__ 
1 


.030 2.5102) 
.015‘ 11£05) 


X 
CHAMFER 
CQATIFSER 
I 
;P1N 1 INDEX 


.100 


ORDERING - PACKAGING 


-°7° (I -77°) 
DlA0S9IA1ND7g)FF 
(2-540) 
DIA TYP 
4 PLS 


1.412135.005) 
1.300 135.255) 
REF 


_ 
3)(3) (_) _ (_)(3)(_ 
_ _ ._, _, 


404(0)\f\f\ 
JLJLJ 
\r\r\ 
JLJCJ 
\ 


TYP 
)1§)1§)(;)(;3 
3 
0 
3 3 3)(3)1(3])1;‘).[ 
;@@@®@@@@@@®@@@ 
1|1)l|o 
o 
o 
o 
o 
o 
o 
0 
o[o)I|[o|l 
©®©®®®®®®Ci@ 


(3)(3) 
(3)(3) 
(3 


() 
(3) 
(3) 


()(3) 
3 
(3) 
(3)(3) 
(3)(3) 
(3) 
(3)(3)(3 
(3) 
(3)(3) 
(3)(3)(3) 
(3)(3)(3 


G) 


_-_____@~ 
(3) 
(3)(3) 
(3)(3)(3) 
(3)(3)(3) 
(3)(3)(3) 
(3)(3) 
(3)(3) 
(3) 
(3) 
(3) 
(3)(3) 
(3) 
(3) 
(3) 


}%@( 
(3) 
@ 
@ 
@ 
3‘(3) 
3)3) 


O 
—\ 
.1 
~®~OOOOOO®OO® 
‘>\ 


3) (3)(3) (3) (3) (3) (3) (3)(3)(3) (3) (_ 


_ 
L_) 


3r‘\ 
(‘\ 1L31 
L3) 
( 
F3r‘\3L3,( 


g,’ 
3 


_ 
_ 
v 
_ 
_ 
_ 
_ 
_ 
_ 
\__j 


1 
» )1’) 
rwr L21 
L1 
'(3) 1 
(3) (3)(3) (3) (3) (3)(3)(3) (3) (3)1 
\ 
_ 


__ 
3.153119.120) 
Y 
-‘°° 


. 
.141 110.914) * 
“T 
I2f§’,I,°I 
.102 14.022) 
13575140-030) 
.121 13.013) 
1-4121335-8365) 
3_3_* 
%}58 
(4_m3)] 
1.559 139.590) 
.099 12.514) 
1.300R1g'5.255) 


.322 (0.101) 
I 
.209 10.032) 
QM 
~H~ 
.190 14.020) 
.11014.310) 
.020 1.500) 
.05011.210) 
.010 1.400) 
4 P‘-9 


UNLESS OTHERWISE SPECIFIED: 


1 


Ulbldki 


ALL METRIC DIMENSIONS ARE IN PARENTHESES. 
METRIC DIMENSIONS ARE IN MILLIMETERS. 
TOLERANCE TO BE 1.005 (0.127). 
MATERIAL: AI;0;. 
LEAD MATERIAL: KOVAR. 
LEAD FINISH IS GOLD PLATING (60 MICROINCHES MIN. THICKNESS) OVER 
NICKEL (100 MICROINCHES NOMINAL THICKNESS). 
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FEATURES 


- Provides hardware assist for bit- 
mapped graphics operations. Includes 
32-bit barrel shifter 


- Performance increase over software 
implementations: 
—Monochrome - 4 x Software 
-Color - 4 x (Planes) x Software 


- Supports both CRT displays and such 
hardcopy devices as laser printers 


- Compatible with both monochrome and 
color displays 


- Implements all 256 possible raster 
operations on source, destination, 
and pattern data 


~ 28- pin package; 5 V supply 


PIN DIAGRAM 
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0713 
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DESCRIPTION 


The VL16160 Raster Op ALU (RALU) 
provides hardware-assisted perform- 
ance enhancements for bit manipulation 
operations used in bit-mapped graphics 
displays. These operations, called bit 
block translation (BITBLT), allow bit- 
mapped images to be combined and 
manipulated by logical operators. 
These operators include AND, OR, and 
XOR, and can be used on source, 
destination, and pattern data. Addition- 
ally, support for masking with multiple 
mask registers for clipping is included. 


The BITBLT operation is general 
purpose enough to be used in a wide 
range of graphics operations, including 
text display using arbitrary fonts, 


BLOCK DIAGRAM 


VL16160 
RASTER OP ALU 


attributes, and enhancements. Succes- 
sive applications of BITBLT can perform 
such operations as scaling, filling, 
rotations, and texturing. 


In a typical application, the RALU 
operates on display data in 16-bit words 
that are latched into its input buffers by 
external hardware. Once source, 
destination, pattern, shift, and masking 
data are loaded into the RALU, the 
source data is bit-aligned with the 
destination data, and the logical 
operation specified in the function 
register takes place. The results are 
stored in the ALU Output Register, 
which can be output onto the bus by a 
single strobe signal. 


15 
0 
15 
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SOURCE 1 


32 BIT BARREL SHIFTER 
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IEIEII 
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ATTERN 
FUNCTION REG 
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DESTINATION 


MASK 
op WIDTH 
EN 
ENABLE 
LOGIC 
OP 0 


OP COUNTER 
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ORDER INFORMATION 


Part 
Number 
Package 


VL16160PC 
Plastic DIP 
VL16160CC 
Ceramic DIP 


i 
an‘ OI 
OI 
‘ 
I 


I 


Q 
O 


-L 
O 
‘ 
MASK 1 


-5 
Q 
‘ 
ALU OUTPUT REG ‘_sTB 


VL16160OC 
Plastic Leaded Chip Carrier (PLCC) 
Note: Operating temperature range is 0°C to +70°C. 
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VL1 61 60-QC 


A2 
A0 
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SIGNAL DESCRIPTIONS 


Signal 
Pln 
Signal 
Name 
Number 
Description 


0o-015 


-cs 
-RD 


-wn 


A0-A3 


-AOSTB 


-LDSTB 


—LSSTB 


GND 


VCC 


6-15 


5 
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1-4 


24 


25 


24 


14 


28 


Bidirectional data lines; input enabled by -CS and -WR. Input data to Destination 
Register must be stable relative to the trailing edge of -LDSTB. Output enabled by -CS, 
-RD, and A0-A3 or -AOSTB. 


Chip Select; Must be active to write to or read from internal registers. 


Read Enable; Input used to strobe any internal register data to the data bus pins. Must 
be active in conjunction with —CS. 


Write Enable; Input used to ‘Strobe data on data bus pins into the selected register. Must 
be active in conjunction with -CS. 


Register Address; Address inputs that specify the internal chip register to be accessed 
for a read or write operation. 


ALU Output Strobe; Input used to enable the output of the function decoder onto the data 
bus pins. Cannot be active when —CS and -RD or -WR are active. 


Load Destination Register Strobe; Input used to strobe the value (address) on the data 
bus pins into the Destination Register. Value on A0-A3 need not be valid when -LDSTB 
is used to load the Destination Register. The -LDSTB pin also decrements the op 
counter each time it is pulsed. 


Load Source Register Strobe; Input used to strobe the value on the data bus into the 
Source Register specified by the Direction Bit. The other Source Register is loaded with 
the previous contents of the Source Register being loaded. 


Ground 


+5 V :l: 5% 
_ 
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FUNCTIONAL 
DESCRIPTION 
The VL16160 consists of four basic 
blocks: Source Shifter, Function 
Decoder, Op Counter, and the Register 
set. The internal data bus is 16 bits 
wide, enabling all internal registers to 
be accessed easily from the I/O bus for 
context saving and restoring. In 
operation, the Source Shifter extracts 
data from the Source Registers and 
shifts the data to be aligned with the 
data in the Destination and Pattern 
Registers. The Function Decoder then 
performs a 16-bit Boolean operation as 
specified by the Function Register with 
the data “extracted from the Source 
Registers and the data in the Destina- 
tion and Pattern Registers. The result of 
the Boolean operation is available on 
the external I/O bus when the -AOSTB 
signal is strobed and can easily be 
written back into display memory. The 
Op counter and associated registers 
provide the support for clipping 
operations as required by the applica- 
tion. 


SOURCE SHIFTEFI 
The Source Shifter performs bit 
alignment on the concatenated 32 bits 
of data in the Source 1 and Source 2 
Registers. The amount of bit alignment 
performed is based upon the value in 
the Shift Value Register. When —LSSTB 
is strobed, the Source Shifter extracts 
16 contiguous bits from the 32 bits of 
data in the Source 1 and Source 2 
registers as follows: 


1. If the low order four bits of the Shift 
Value Register have a non-zero 
value, that value specifies the shift 
count by which the 16-bit field to be 
extracted is offset from bit O of the 
concatenated source registers, as 
shown in Figure 1. The result is 
passed on to the Function Decoder. 


2. ll the low-order four bits of the Shift 
Value Register is 0, the contents of 
either Source 1 or Source 2 are 
passed directly to the Function 
Decoder and no shifting occurs. The 
direction bit indicates which source 
register is used in the operation, as 
shown in Figure 1. 


FUNCTION DECODER 
The Function Decoder performs a 
Boolean operation on the contents of 
the Destination Register, Pattern 
Register, and the output of Source 
Shifter. The Boolean operation is 
specified by the Function Register. With 
the three operands, 256 different 
Boolean operations are possible. The 
result of the operation is available on the 
I/O bus when the -AOSTB control signal 
is active. -AOSTB signal cannot be 
active at the same time that -CS and 
-RD or -WR are active. The result of 
the Boolean operation is also available 
by reading the ALU Output Register. 


To understand how the Function 
Decoder performs the desired Boolean 
operation, note again that with three 
operands, (data in the Source, Pattern 
and Destination Registers), a total of 
256 different boolean operations is 
possible. Out of these 256 possible 
operations, the application defines 
which are needed to perform the desired 
task. 


For example (see Figure 2), to "paint" a 
new image over an existing image 
requires the source data (image) to be 
ORed with the destination data (image). 
This means ‘Source Register OR the 
Destination Register". For each bit, 
there are four possible results of this 
operation between these two registers. 
However, since the Pattern Register is 
always included, even when it is a "don't 
care,"'a total of eight different possible 
results of this one Boolean operation is 
possible. These eight combinations 
define the “function code" for the overlay 
operation. Thus, the function code is 
really defined as the result (and the only 
result possible) of a Boolean combina- 
tion of the Source, Destination, and 
Pattern Registers. In using the 
VL16160, the application defines which 
of the 256 possible Boolean combina- 
tions of the Source, Destination and 
Pattern Registers define those "func- 
tions" required of the application, and 
when that “function” is required, the 
corresponding function code is loaded 
into the Function Register. 


In principal, the Function Decoder 
operates on a bit-by-bit basis as a 1-of-8 
data selector with each data bit in the 
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Source, Destination, and Pattern 
Registers selecting one of eight bits of 
data from the Function Register. 


The function codes required of an 
application are determined ahead of 
time by the user and stored in memory 
to be used as needed. The determina- 
tion of the correct function code is a 
matter of simply applying the definitions 
stated above (see Figure 2), in a simple 
method. The truth table for Pattern, 
Source, and Destination bits is written, 
with the desired output. This desired 
output is read as the desired value of 
the Function Register, with the least 
significant bit as shown in Figure 2. 
Using this method, the software 
engineer can easily define a pattern to 
suit each specific need. 


OP COUNTER 
The Op Counter, in conjunction with the 
Width and Mask Registers, provides for 
masking of selected bits in the Destina- 
tion Register. This masking prevents the 
VL16160 from modifying selected areas" 
of display memory when performing 
BlTBLTs. For example, clipping may be 
required at the edges of a window. The 
function of the Op Counter is to keep 
track of the beginning and end of each 
row, so that the mask registers can 
handle this clipping automatically, 
without additional processor interven- 
tion. 


The Op Counter must be correctly 
initialized prior to the beginning of a 
raster operation. The enabling of 
masking is internally clocked by the 
-LDSTB signal. For this reason, after 
loading the Op counter with an initial 
value, -LDSTB must be pulsed before 
the —LSSTB of the first operation. Since 
this -LDSTB will decrement the Op 
Counter, it is necessary to increment the 
Op Counter to be one more than the 
intended value, so that this “dummy” 
-LDSTB starts out the BITBLT with the 
correct Op Counter value. This "dummy" 
-LDSTB does have to be repeated 
between scanlines, as the masking 
remains enabled. If context switching is 
utilized, however, reinitialization (with 
the loading of Op Counter and subse- 
quent -LDSTB) is necessary before 
leaving a context, or upon re-entering 
one, in the middle of a BITBLT. 
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REGISTER DESCRIPTION 
As shown in the block diagram, the 
RALU consists of a number of registers, 
each connected to the internal 16-bit 
data path. Of these registers, three are 
used very often and are directly acces- 
sible from the data bus by the assertion 
of strobe signals. 


SOURCE 
The Source Register holds a 16-bit word 
of data to be modified by a raster 
operation. It is loaded from the data bus 
by the assertion of the —LSSTB signal. 


DESTINATION 
The Destination Register holds a word 
of data from the bit-mapped display that 
is modified by the source data and 
raster operation. It is loaded from the 
data bus when -LDSTB is asserted. 


ALU OUTPUT 
The ALU Output Register holds the 
result of the raster operation to be 
written back to memory. The contents 
may be put onto the data bus by the 
assertion of the -AOSTB signal. 


The remainder of the registers are 
typically set up for a series of operations 
and are not changed until the end of a 
scan line. 


FIGURE 1. SHIFTING AND DIRECTION 


DIR / SHIFT 
This register controls the direction of the 
raster operation (left-to-right or right-to- 
left). In addition, it specifies the number 
of bits to shift to align the source with 
the destination fields. 


MASK 1 and 2 
These registers are used to define the 
left and right boundaries of the area on 
the screen that is manipulated. (The 
direction bit affects which register 
corresponds to left vs. right). 
A bit set 
in these registers allows the corre- 
sponding bit in the Destination Register 
to pass through unaltered. When the Op 
Counter is equal to the Width Register 
(usually for the first raster operation on 
each scan line), the Mask 1 Register 
selects bits to be included in the 
operation. Masking is disabled until the 
Op Counter is zero (usually for the last 
operation on a scan line); at that time, 
the Mask 2 register is used. 


PA1TERN 
This register contains data to be 
combined with the output of the bit- 
shifted source register. This is com- 
monly used for enhancing an image 
with a background pattern. 


D15 
D8 D7 
D0 
SW 
S*""’ WE 


DIRECTION I SHIFT VALUE REGISTER 
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FUNCTION 
This register contains the operator that 
is used to combine the source, destina- 
tion, and pattern data. 


OP COUNTER 
The Op Counter Register specifies the 
current count of the operation in 
progress. The Op Counter is decre- 
mented each time -LDSTB is brought 
active. After the Op counter goes to 
zero, the next -LDSTB causes the Op 
counter to be reloaded with the value of 
the Width register prior to the next 
operation. The Op counter can be set to 
the value of the Width Register at the 
start of a raster operation by beginning 
an operation with a "dummy" -LDSTB. 
This loads the Op counter in preparation 
for the first scan line. 


WIDTH 
The Width Register specifies the width 
of the line (in 16-bit words) on which 
raster operations will take place. 


FLAG REGISTER 
The Flag Register is uncommitted and 
can be used to temporarily store context 
information for multi-tasking implemen- 
tations. 


(DATA BUS) 
SOURCE 2 
SOURCE 1 
DIRECTION = 0 


(DATA Bus) 
SOURCE 1 
SOURCE 2 
DIRECTION = 1 
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TABLE 1. REGISTER MAP 
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Destination Register 


Source 1 Register 


Source 2 Register 


Pattern Register 


Maskf Register 


Mask 2 Register 


Shift Value Register 


Function Register 


Width Register 


Operation Count 
Register 


ALU Output Register 


Reserved 


Reserved 


Reserved 


Reserved 


Flag Register 
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FIGURE 2. RASTER OPERATIONS EXAMPLE 
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FIGURE 2d. SOURCE XOR DESTINATION OR PAT. (6F16) 
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FIGURE 2b. SOURCE OR DESTINATION (7715) 
FIGURE 20. SOURCE OR DESTINATION OR PAT. (7F16) 
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FIGURE 2c. SOURCE OVERLAY DESTINATION (3316) 
FIGURE 21. SOURCE OVERLAY DEST. OR PAT. (1 F16) 
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ABSOLUTE MAXIMUM RATINGS 
u 
Supply Voltage 
-0.5 V to +7.0 V 
Stresses above those listed under 
under these or any other conditions 
Input Voltage 
-0.5 V to +7.0 V 
‘Absolute Maximum Ratings‘ may 
above those listed in this specification 
Output Voltage 
-0.5 V to +7.0 V 
cause permanent damage to the 
is not Implied. Exposure to absolute 
Operating Temperature 
0°C to +70°C 
device. These are stress ratings only. 
maximum ratings conditions for 
Storage Temperature -65°C to +150°C 
Functional operation of this device 
extended periods may affect device 
Lead Temperature (10 s.) 
300°C 
Junction Temperature 
175°C 


DC CHARACTERISTICS TA: 0<>c10 +70<>c, vcc= s v 10.25 v 


Symbol 
Parameter 
T 
Condltlons 


0SS 
...'_I 


P -b 
Z 


-L 


High Level Input Voltage 


Low Level Input Voltage 


VOH 
High-Level Output Voltage 
VCC- Min; lOH=- -400 pA 


VOL 
Low Level Output Voltage 
VCC-= Min; IQI--= 4-4 m/\ 


0 n 
1| v 1 


IOL 
Low Level Outut Current 


IIL 
Input Leakage Current 
|,1 
VI - 0.45 V 


O 7 V < Vo < Vcc 
ll/O 
VO Leakage Current 
0.4 V < Vo < VCC 


ICC 
Power Supply Current at DC 
120 
M 
VCC-= Max 


CAPACITANCE TA= 0~c to +10<>c 


Symbol 
Parameter 
III°"9 


CVO 
I/O C8p8CI18flC8 


Input C8p8CI‘I8l’IC6 
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AC TIMING CHARACTERISTICS 
TA = 0<>c10 +1000, vcc = s v ¢ 0.25 v 
Symbol 
Parameter 


q-LO1O 


‘,5 
-5-L 


\I 
I\J 


8OO 


tCSH 
-CS A0-A3 Hold After -WR Active 


tRWW 
-WR -RD Signal Width 


tCSS 
-CS, A0-A3 Setup to -WR Inactive 


CSV 
Data Valid After —CS Active 


tRDV 
Data Valid After -RD Active 


tRDH 
Data Valid After -RD -CS Inactive 


tWRS 
Data Setup to -WR Inactive 


tWRH 
Data Hold After -WR Inactive 


tLSW 
—LSSTB Pulse Width 


tNLS 
Time Between —LSSTB Pulses 


tSDV 
—LSSTB Inactive to Valid Data 


LSF 
—LSSTB Inactive to AOstb Active 


tLDV 
—LSSTB Active to Valid Data 


tLDW 
-LDSTB Pulse Width 


tNLD 
Time Between -LDSTB Pulses 


tLDF 
-LDSTB Inactive to -AOSTB Active 


tLSS 
Data Setup to —LSSTB Inactive 


tLSH 
Data Hold after —LSSTB Inactive 


tLDS 
Data Setup to -LDSTB Inactive 


tLDH 
Data Hold After -LDSTB Inactive 


tFOV 
Data Valid After -AOSTB Active 


tDDV 
Data Valid After Valid -LDSTB Data 


tFDV 
Bus High lmpedence After -AOSTB Inactive 
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FIGURE 3. REGISTER READIWRITE TIMING 
VL16160 
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FIGURE 4. SOURCE REGISTER AND ALU OUTPUT CONTROL SIGNAL TIMING 
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FIGURE 5. TYPICAL APPLICATION 
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FEATURES 
- Full double buffering 


- Independent control of transmit, 
receive, line status and data set 
interrupts 


- Modem control signals include —CTS, 
-HTS, -DSR, -DTR, —-RI and —DCD 


- Programmable serial interface 
characteristics: 
— 5-, 6-, 7- or 8-bit characters 
- Even-, odd-, or no-parity bit 
generation and detection 
-1-, 1 112- or 2-stop bit generation 
- Baud rate generation (dc to 56K 
baud) 


- Full status reporting capabilities 


- Three-state TIL drive capabilities for 
bidirectional data bus and control bus 


VL16C450 - VL82C50A - VL82C50 
ASYNCHRONOUS COMMUNICATIONS ELEMENT 


DESCRIPTIONS 
The VL16C450 is an asynchronous 
communications element (ACE) that is 
functionally equivalent to the 
VL82C50A, but is an improved specifi- 
cation version of that part. The 
improved specifications provide 
ensured compatibility with state-of-the- 
art CPUs. 


The VL16C450, VL82C50A, and 
VL82C50 ACEs serve as serial data 
input/output interface in microcomputer 
systems. They perform seriaI-to- 
parallel conversion on data characters 
received from peripheral devices or 
modems, and parallel-to-serial conver- 
sion on data characters transmitted by 


the CPU. The complete status of the 
ACE can be read at any time during 
functional operation by the CPU. The 
information obtained includes the type 
and condition of the transfer operations 
being performed, and error conditions 
involving parity, overrun, framing, or 
break interrupt. 


A programmable baud rate generation 
is included that can divide the timing 
reference clock input by a divisor 
between 1 and (2 6-1). 


The VLSI family of ACEs is available 
packaged in plastic leaded chip carrier 
as well as a plastic and ceramic DIP. 


—DCD‘ 
PIN DIAGRAMS 
be 
01 
N.C. 
-RI -osn 


VL16C450 
VL82C50A 
VL82C50 


D0 I 
D1 I 
D2 I 
D3 I 
D4 I 
D5 I 
D6 I 
D7 I 
FICLK I 
SIN I 
SOUT I 
CSO I 
CS1 I 
-CS2 I 
-BAUDOUT I 
XTAL1 I 
XTAL2 I 


I vcc 
I -FII 
I -000' 
I -osn 
I -crs 
I MR 
I —OUT1 
I -om 
I -are 
I -OUT2 
IINTRPT 
I ~.c. 
I A0 
I A1 
I A2 
I -ADS 
I csour 


VL16C45O 
VL82C50A 
I, 
8 
v|.a2cso 
D6 .. 8 


D7 I 
9 
RCLK I 
10 
SIN I 
11 


N.C. I 
12 
SOUT I 
13 


CSO I 
14 


CS1 I 
15 
-CS2 I 
16 
-BAUDOUT I 
17 


9 


Q 
ml 
mi 
#~I 
wl 
roI8 


.-I 


in 3i $1 n 83 


D2 
VCC 
TS 


39 I 
MR 
38 I 
—OUT1 
37 I 
—DTR 
36 I 
—RTS 
35 I 
—OUT2 
34 I 
N.C. 
33 I 
INTRPT 
32 I 
N.C 


31 I 
A0 
30 I 
A1 
29 I 
A2 


IE; IE5 I8 I9. I8 IE3 I? II)! I8 I13 I8 


XTAL1 
VSS 
DDIS 
—ADS 


XTAL2 
N.C. 
CSOUT 


-DOSTR 
—DISTR 


DOSTR 
DISTH 


ORDER INFORMATION 


—DOSTFI I 
18 
23 I DDIS 
DOSTFI I 
19 
22 I DISTR 
VSS I 20 
21 I —DlSTR 


‘On the VL82C50, Pin 38 (Pin 42 on 
the PLCC package) is also called 
-RLSD. 


Part 
Number 


VL16C450-PC 
VL16C450-CC 
VL1 BC450-QC 


VL82C50A-PC 
VL82C50A-CC 
VL82C50A-QC 


VL82C50-PC 
VL82C50-CC 
VL82C50-QC 


Clock 
Frequency 


3 1 MHz 


Package 


Plastic DIP 
Ceramic DIP 


Plastic DIP 
Ceramic DIP 


Plastic DIP 
Ceramic DIP 


Note: Operating temperature range is 0°C to + 70°C. 
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Plastic Leaded Chip Carrier (PLCC) 


Plastic Leaded Chip Carrier (PLCC) 


Plastic Leaded Chip Carrier (PLCC) 


N 


BLOCK DIAGRAM 


(1 -9) 
DATA 
RECEIVER 
RECEIVER 
D907ii 1 
BUFFER I 
sr-m=r 
BUFFER 
neersrrsn 
REGISTER 


RECEIVER 
1- NE 
ammo 
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T 3, 
FICI-K 
REGISTER 
QQNTRQL 
A0 


A1 


A2 


cso 
cs1 
-cs2 
-ADS 


MR 
orsm 
-orsrn 
oosrn 
-oosrrt 
oors 


CSOUT 


XTAL1 


XTAL2 


(40) 
POWER -_l--> +sv 


SUPPLY -_Z_-> one 


(29) 


(37) 


(29) 


(12) 


(13) 


(14) 


(25) 


(35) 


(32) 


(21) 


(1 9) 


(19) 


(33) 


(24) 


(19) 


11‘<’_ 


SELECT 
81 
CONTROL 
LOGIC 


I 


I 
IIII 
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iL|||T 
[Ell 


Ii‘ 


orvrson 
LATCH (LS) 


orvrson 
LATCH (LS) 


STATUS 
REGISTER 


HOLDING 
REGISTER 


MODEM 
CONTROL 
REGISTER 


STATUS 
REGISTER 


INTERRUPT 
ENABLE 
REGISTER 


INTERRUPT 


TRANSMITTER 
TRANSMITTER 


REGISTER 


I 


Note: Applicable pin numbers (DIP) are included within parentheses. 
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RECE 
ER 
L NE 
TIMING 


SHIFT 


MODEM 
CONTROL 
MODEM 
I-°G'° 


INTERRUPT 
CONTROL 
LOGIC 


(19) 


(11) 


(32) 


(39) 


(33) 


(37) 


(39) 


(39) 


(34) 


(31) 


(39) 
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SIN 


(15) 
GENERATOR 
-BAUDQUT 


SOUT 


-RTS 
-crs 
-urn 
-osn 
Ioco 


-RI 


—OUT1 


-OUT2 


INTRPT 


® VLSI TECHNOLOGY, INC. 
VL16C450 - VL82C50A - VL82C50 


SIGNAL DESCRIPTIONS 


Slgnal 
Name 
Pln 
Number (DIP) 
Slgnal 
Type 
Slgnal 
Descpon 


D0-D7 


RCLK 


SIN 


SOUT 


CSO, CS1 , 
CS2 


-BAUDOUT 


XTAL1 


XTAL2 


-DOSTR 


DOSTR 


VSS 


—DISTR 


DISTTI 


DDIS 


csour 


—ADS 


AOAQ 


NC 


INTRPT 


1-8 


9 


10 


11 


12-14 


15 


16 


17 


18 


19 


20 


21 


22 


23 


24 


25 


28-26 


29 


30 


I/O 


O 


I 


O 


I 


I 


I 


O 


O 


I 


I 


O 


Data Bits 0 through 7 - The Data Bus provides eight, three-state I/O lines 
for the transfer of data, control and status information between the ACE 
and the CPU. These lines are normally in a high-impedance state except 
during read operations. D0 is the least significant bit (LSB) and is the first 
serial data bit to be received or transmitted. 


Receive Clock Input - The external clock input to the UART baud rate 
divisor. 


Serial Data Input - The serial data input moves information from the 
communication line or modem to the ACE receiver circuits. A mark (1) is 
high, and a space (O) is low. Data on serial data input is disabled when 
operating in the Loop Mode. 


Serial Data Output - This line is the serial data output from the UART’s 
transmitter circuitry. A mark (1) is a logic "one" (high) and space (0) is a 
logic “zero” (low). SOUT is held in the mark condition when the transmitter 
is disabled, Reset is true, the Transmitter Register is empty, or when in the 
Loop Mode. 


Chip Selects - The Chip Select inputs act as an enable for the device. 
When -CS2 is low and CSO and CS1 are both high, the chip is selected. 


Baud Rate Output - This output signal for the transmitter section is equal to 
the internal reference frequency, divided by the selected divisor. 


Crystal Input Pin 1 - Input for external timing reference input or pin of 
crystal (See Basic Configuration). 


Crystal Input Pin 2 - Input for pin of crystal (See Basic Configuration). 


Input/Output Write Strobe - This is an active low input which causes data 
from the data bus (D0-D7) to be input to the UART. 


Input/Output Write Strobe - Same as -DOSTR, but uses an active high 
input 


Ground (0 V). 


Input/Output Read Strobe - This is an active low input which causes the 
serial channel to output data to the data bus (DBO-DB7). 


Input/Output Read Strobe - Same as -DISTR, but uses an active high 
input 


Driver Disable - This pin goes low whenever the microprocessor is reading 
data from the ACE. This signal may be used to disable an external trans- 
ceiver. 


Chip Select Out - A high on this pin indicates that the chip has been 
selected by the chip select input pins. 


Address Strobe Input - When this pin is low, the state of the Register Select 
and Chip Select pins is latched internally. 


Address Lines A0-A2 - The address lines select the internal registers 
during CPU bus operations. 


No Connection. 


Interrupt Output - This pin goes high (when enabled by the Interrupt 
Enable Register) whenever a Receiver Error Flag, Received Data Avail- 
able, Transmitter Holding Register Empty, or Modem Status condition is 
detected. 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number (DIP) 
q 
Type 
Descrlptlon 


-OUT2 
31 
O 
Output 2 - User defined output that can be set to an active low by program- 
ming bit 3 of the Modem Control Registerto a high level. 


—RTS 
32 
O 
Request to Send - The —RTS signal is an output on the UART used to 
enable the modem. The -RTS pin is set low by writing a logic 1 to MCR bit 


1 of the UART’s Modem Control Register. The —RTS pin is reset high by 
Reset. A low on the —RTS pin indicates to the ACE that the UART has 
data ready to transmit. 


—DTR 
33 
O 
Data Terminal Ready - The DTR pin can be set (low) by writing a logic 1 to 
MCR, Modem Control Register bit 0 of the UART. This signal is cleared 
(high) by writing a logic 0 to the DTR bit (MCR) or whenever a reset occurs. 
When active (low), the DTR pin indicates to the ACE that the UART is 
ready to receive data. 


—OUT1 
34 
O 
Output 1 - User defined output that can be set to an active low by pro- 
gramming bit 2 of the Modem Control Register to a high level. 


MR 
35 
I 
Master Reset - When high, the reset input forces the ACE into an idle 
mode in which all data activities are suspended. The Modem Control 
Register (MCR) along with its output, is cleared. The Line Status Register 
(LSR) is cleared except for the THRE and TEMT bits, which are set. All 
functions of the device remain in an idle state until programmed to resume 
activities. 


—CTS 
36 
I 
Clear to Send - The logical state of the —CTS pin is reflected in the CTS bit 
of the (MSR) Modem Status Register [CTS is bit 4 of the MSR, written 
MSR(4)] of the UART. A change of state of the -CTS pin, since the 
previous reading of the MSR causes the setting of DCTS in the Modem 
Status Register. When the —CTS pin is low, the modem is indicating that 
data on SOUT can be transmitted. 


-DSR 
37 
I 
Data Set Ready - The logical state of the -DSR pin is reflected in MSR(5) 
of the Modem Status Register. DDSR MSR(1) indicates whether the -DSR 
pin has changed state since the previous reading of the MSR. When the 
-DSR pin is low, the modem is indicating that it is ready to exchange data 
with the UART. 


—DCD (-RLSD) 
38 
I 
Data Carrier Detect (Receive Line Signal Detect) - When low, the —DCD 
(-RLSD) indicates that the data carrier has been detected by the modem or 
data set. —DCD (-RLSD) is a modem input whose condition can be tested 
by the CPU by reading MSR(7) (DCD or RLSD) of the Modem Status 
Register. MSR(3) (DDCD or DRLSD) of the Modem Status Register 
indicates whether the —DCD (-RLSD) input has changed since the previ- 
ous reading of the MSR. —DCD (-RLSD) has no effect on the receiver. If 
the —DCD (—RLSD) changes state with the modem status interrupt en- 
abled, an interrupt occurs. 


—Rl 
39 
I 
Ring Indicator Input - When low, —Rl indicates that a telephone ringing 
signal has been received by the modem or data set. The -RI signal is a 
modem control input whose condition is tested by reading MSR(6) (RI) of 
the UART. The Modem Status Register output TERI MSR(2) indicates 
whether the RI input has changed from high to low since the previous 
reading of the MSR. If the interrupt is enabled lER(3) = 1 and -RI changes 
from a high to low, an interrupt is generated. 


VCC 
40 
Power Supply - The power supply requirement is 5 V :t5%. 
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REGISTERS 
Three types of internal registers are used 
in the serial channel of each ACE. They 
are used in the operation of the device, 
and are the control, status, and data 
registers. The control registers are the 
Bit Rate Select Register DLL (Divisor 
Latch LSB) and DLM (Divisor Latch 
MSB), Line Control Register, Interrupt 
Enable Register, and the Modem Control 
registers, while the status registers are 
the Line Status Registers and the 
Modem Status Register. The data 
registers are the Receiver Buffer 
Register and the Transmitter Holding 
Register. The Address, Read, and Write 
inputs are used in conjunction with the 
Divisor Latch Access Bit in the Line 
Control Register [LCR(7)] to select the 
register to be written or read (see Table 
1). Individual bits within these registers 
are referred to by the register mnemonic 
and the bit number in parenthesis. 
As 
an example, LCR(7) refers to Line 
Control Register Bit 7. 


The Transmitter Buffer Register and 
Receiver Buffer Register are data 
registers that hold from five to eight bits 
of data. If less than eight data bits are 
transmitted, data is right justified to the 
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LSB. Bit O of a data word is always the 
first serial data bit received and transmit- 
ted. The ACE data registers are double- 
buffered so that read and write opera- 
tions may be performed when the UART 
is performing the parallel-to-serial or 
serial-to-parallel conversion. 


The format of the data character is 
controlled by the Line Control Register. 
The contents of the LCR may be read, 
eliminating the need for separate storage 
of the line characteristics in system 
memory. The contents of the LCR are 
described below: 


LCR (O) Word Length Select Bit 0 
(WLSO) 
LCR (1) Word Length Select Bit 1 
(WLS1) 
LCR (2) Stop Bit Select (STB) 
LCR (3) Parity Enable (PEN) 
LCR (4) Even Parity Select (EPS) 
LCR (5) Stick Parity 
LCR (6) Set Break 
LCR (7) Divisor Latch Access Bit (DLAB) 


LCR(0) and LCR(1) word length select 
bit 1: The number of bits in each serial 
character is programmed as shown in 
Table 2. 


TABLE 1. SERIAL CHANNEL INTERNAL REGISTERS 
mmm@ 


0 
0 
0 
0 
RBR 


O 
O 
O 
O 
THR 


0 
0 
0 
1 
IER 


X 
0 
1 
0 
IIR 


X 
0 
1 
1 
LCR 


X 
1 
0 
0 
MCR 


X 
1 
0 
1 
LSR 


X 
1 
1 
0 
MSR 


X 
1 
1 
1 
SCR 


1 
0 
0 
0 
DLL 


1 
0 
0 
1 
DLM 


X == "Don’t Care” 
O = Logic Low 


Reglster 


Receiver Buffer Register (read only) 


Transmitter Holding Register (write only) 


Interrupt Enable Register 


Interrupt Identification Register (read only) 


Line Control Register 


Modem Control Register 


Line Status Register 


Modem Status Register 


Scratch Register 


Divisor Latch (LSB) 


Divisor Latch (MSB) 


1 = Logic High 


Note:The serial channel is accessed when —CSO is low. 


39 


TABLE 2. WORD LENGTH 
SELECT 


LCR(1) 
LCR(0) 
Word Length 


5 Bits 
6 Bits 
7 Bits 
8 Bits 
_;_;QQ 
.-Lc)_;@ 


LCR(2) Stop Bit Select: LCR(2) speci- 
fies the number of stop bits in each 
transmitted character. 
If LCR(2) is a 
logic 1 when a 5-bit word length is 
selected, 1.5 stop bits are generated. 
If 
LCR(2) is a logic 1 when either a 6-, 7-, 
or 8-bit word length is selected, two stop 
bits are generated. The receiver checks 
for two stop bits if programmed to do so. 


LCR(3) Parity Enable: When LCR(3) is 
high, a parity bit between the last data 
word bit and stop bit is generated and 
checked. 


LCR(4) Even Parity Select: When parity 
is enabled [LCR(3) = 1], LCR(4)—0 
selects odd parity, and LCR(4) = 1 
selects even parity. 


LCR(5) Stick Parity: When parity is 
enabled [LCR(3)—1], CLR(5) = 1 causes 
the transmission and reception of a 
parity bit to be in the opposite state from 
that indicated by LCR(4). This allows 
forced parity to a known state and the 
receiver to check the parity bit in" a 
known state. 


LCR(6) Break Control: When LCR(6) is 
set to a logic "1", the serial output 
(SOUT) is forced to the spacing (logic 0) 
state. The break is disabled by setting 
LCR(6) to a logic "O". The Break Control 
bit acts only on SOUT and does not 
effect on the transmitter logic. Break 
Control enables the CPU to alert a 
terminal in a computer communications 
system. If the following sequence is 
used, no invalid characters will be trans- 
mitted because of the break. 


1. 
Load all "0”s pad character in 
response to THRE. 


2. Set the break in response to the next 
THRE. 


3. Wait for the transmitter to be idle 
(TEMT =1), then clear the break 
when the normal transmission has to 
be restored. 
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FIGURE 1. LINE CONTROL REGISTER 


LCR 
LCR LCR 
LCR 
LCR 
LCR 
LCR 
|_cR 
7 
e 
s 
4 
3 
2 
1 
o 


-5-500 
-Lo-L 


O 
Word 
Length 
Select 


Stop 
Bit Select 
1 = 


Parity 
Enable 


5 Data Bits 
6 Data Bits 
7 Data Bits 
8 Data Bits 


0 = 
1 SIOD BIT 
1.5 Stop Bits if 5 Data Bits Selected 
2 Stop Bits if 6, 7, 8 Data Bits Selected 


0 = Parity Disabled 
1 = Parity Enabled 


Even 
0 = Odd Parity 
Parity 
1 = Even Parity 
Select 


Stick 


Break 
0 = 
Control 


0 = Stick Parity Disabled 
Parity 
1 = Stick Parity Enabled 


Break Disabled 
1 = Break Enabled 


Divisor 
0 = Access Receiver Buffer 
Latch 
1 = Access Divisor Latches 
Access 
Bit 


LCR(7) Divisor Latch Access Bit (DLAB); 
Receiver Buffer Register has been 
LCR(7) must be set high (logic "1 ") to 
overwritten by a character from the 
access the Divisor Latches DLL and 
Receiver Shift Register before being 
DLM of the Baud Rate Generator during 
read by the CPU. The character is 
a read or write operation. LCR(7) must 
thereby lost. 
Framing Error (FE) 
be input low to access the Receiver 
indicates that the last character received 
Buffer, the Transmitter Holding, or the 
contained incorrect (low) stop bits. This 
Interrupt Enable Registers. 
is caused by the absence of the required 
The Line Status Register (LSR) is a 
81°” b" °' “Y 3 s‘°l’ bi‘ ‘°° ‘t"°.“ 1° b° 
singb register that provides status 
detected. Parity Error.(PE) |ndrcates_that 


indications. The LSR is usually the first 
the last character recewed had a pamy 
error based on the programmed and 
the cause of an interrupt or to poll the 
calculated parity of the received charac- 
register read by the CPU to determine 


status the serial channel of the ACE. 
tar‘ 


Three error flags OE, FE, and PE 
Th? Break Interrupt (Bl) status bit 
provide the Status of any error conditions 
IndIC818S that the last character received 


detected in the receiver circuitry. During 
rv$si'saa?rri°:/irciga:;:g?:rr;a’§‘a:{§kr?r::'_a°' 
reception of the stop bits, the error flags 
. 
. 
. 
h 
are set hrgh by an error ormdmorr. The 
ever, rt IS an entire c aracter, including 


error flags are not reset by the absence 
pamy and stop MS‘ 
of an error condition in the next received 
The Transmitter Holding Register Empty 
character. The flags reflect the last 
(THRE) bit indicates that the THR 
character only if no overrun occurred. 
register is empty and may receive 
The Overrun Error character in the 
' 
another character. The Transmission 
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Shift Register Empty (TEMT) bit indi- 
cates that the Transmitter Shift Register 
is empty, and the serial channel has 
completed transmission of the last 
character to be sent. If the interrupt is 
enabled [IER(1)], an active THRE 
causes an interrupt (INTRPT). 


The Data Ready (DR) bit indicates that 
the RBR has been loaded with a 
received character (including Break) and 
that the CPU may access this data. 


Reading the LSR clears LSR(1)-LSR(4). 
(OE, PE, FE, and Bl.) 


The Line Status Register shown in Table 
3 is described below: 


LSR(0) Data Ready (DR): Data Ready is 
set high when an incoming character has 
been received and transferred into the 
Receiver Buffer Register. LSR(0) is 
reset low by a CPU read of the data in 
the Receiver Buffer Register. 


LSR(1) Overrun Error (OE): Overrun 
Error indicates that data in the Receiver 


- VL82C50 
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TABLE 3. LINE STATUS REGISTER BITS 


LSR BITS 


LSR(O) Data Ready (DR) 


LSR(1) Overrun Error (OE) 


LSR(2) Parity Error (PE) 


LSR(3) Framlng Error (FE) 


LSR(4) Break Interrupt (Bl) 


LSR(5) Transmitter Holding Register Empty (THRE) 


LSR(6) Transmitter Empty (TEMT) 


LSR(7) Not Used 


Ready 


Error 


Error 


Error 


Break 


Logic 0 


Not Ready 


No Error 


No Error 


No Error 


No Break 


Empty 


Empty 


Not Empty 


Not Empty 


Buffer Register was not read by the CPU 
LSR(5) Transmitter Holding Register 
before the next character was trans- 
ferred into the Receiver Buffer Register, 
overwriting the previous character. The 
OE indicatoris reset whenever the CPU 
reads the contents of the Line Status 
Register. 


LSR(2) Parity Error (PE): Parity Error 
indicates that the received data charac- 
ter does not have the correct even or 
odd parity, as selected by the Even 
Parity Select bit LCR(4). The PE bit is 
set high upon detection of a parity error, 


Empty (THRE): THRE indicates that the 
ACE is ready to accept a new character 
for transmission. The THRE bit is set 
high when a character is transferred from 
the Transmitter Holding Register into the 
Transmitter Shift Register. LSR(5) is 
reset low by the loading the Transmitter 
Holding Register by the CPU. LSR(5) is 
reset low by the loading of the Transmit- 
ter Holding Register by the CPU. LSR(5) 
is not reset by a CPU read of the LSR. 


When the THRE interrupt is enabled 
and is reset low when the CPU reads the 
lER(1). THRE causes a priority 3 
' 
contents of the LSR. 


LSR(3) Framing Error (FE): Framing 
Error indicates that the received charac- 
ter did not have a valid stop bit. LSR(3) 


interrupt in the IIR. If THRE is the 
interrupt source indicated in IIR, INTRPT 
is cleared by a read of the IIR. 


LSR(6) Transmitter Empty (TEMT): 
is set high when the stop bit following the 
TEMT is set high when the Transmitter 
last data bit or parity bit is detected as a 
Holding Register (THR) and the Trans- 
zero bit (spacing level). The FE indicator 
mitter Shift Register (TSR) are both 
is reset low when the CPU reads the 
contents of the LSR. 


LSR(4) Break Interrupt (Bl): Break 
Interrupt is set high when the received 
data input is held in the spacing (logic 0) 


empty. LSR(6) is reset low when a 
character is loaded into the THR and 
remains low until the character is 
transferred out of SOUT. TEMT is not 


reset low by a CPU read of the LSR. 


LSR(7): This bit is always 0. 


The Modem Control Register (MCR) 
controls the interface with the modem or 
data set as described in Table 4 and 
Figure 2. MCR can be written and read. 
The -RTS and -DTR outputs are directly 
controlled by their control bits in this 
register. A high input asserts a low (true) 
at the output pins. MCR Bits 0, 1, 3, and 
4 are shown below: 


MCR(0): When MCR(0) is set high, the 
-DTR output is forced low. When 
MCR(0) is reset low, the -DTR output is 
forced high. The -DTR output of the 
serial channel may be input into an 
inverting line driver in order to obtain the 
proper polarity input at the modem or 
data set. 


MCR(1): When MCR(1) is set high, the 
RTS output is forced low. When MCR(1) 
is reset low, the -RTS output is forced 
high. 


MCR(2): The -RTS output of the serial 
channel may be input into an inverting 
line driver in order to obtain the proper 
polarity input at the modem or data set. 


MCR(3): When MCR(3) is set high, the 
—OUT1 or -OUT2 output is forced high. 


MCR(4): MCR(4) provides a local 
loopback feature for diagnostic testing of 
the channel. When MCR(4) is set high, 
Serial Output (SOUT) is set to the 
marking (logic “1”) state, and the receiver 
data input Serial Input (SIN) is discon- 
nected. The output of the Transmitter 
Shift Register is looped back into the 
Receiver Shift Register input. The three 


SP9“ 1°’ '°"9°' "Fa" a‘""‘f'°"“'a'?$"“$' 
TABLE 4. MODEM CONTROL REGISTER BITS 
sion time (start bit + data bits + parity + 
stop bits) 
The Bl indicator is reset when 
MCR Bit 
L 
' 0 
. 
s 
ogic 
the CPU reads the contents of the Line 
, 
_ 
status Register 
MCR(0) Data Terminal Ready (DTR) 
-DTR Output Low 
-DTR Output High 


that produce a Receiver Line Status 
MCRQ) QU1-1 
_OU-I-1 Output Low 
__QU-H Qutput High 
interrupt (priority 1 interrupt in the 
Interrupt Identification Register (llR)) 
MCRI3) OUT? 
-QUT3 09191111-°W 
-QUT2 QUIPU1 High 
when any of the conditions are detected. 
R 
O0 
L 
E 
bl d 
L 
0- 
bl d 
This interrupt is enabled by setting 
MC (4)L 
P 
Cop 
na 
8 
cop 
ma 
8 
lER(2) -I 1 in the Interrupt Enable Regis- 
ter. 
MCR(5) 0 


MCR(6) 0 


MCR(7) 0 
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FIGURE 2. MODEM CONTROL REGISTER 


MCR MCR MCR MCR 
MCR MCR 
RR 
i 
Data 
0 = -DTR Output High (Inactive) 
Terminal 
1 = -DTR Output Low (Active) 
Ready 


Request 
O = -RTS Output High (Inactive) 
To Send 
1 = -RTS Output Low (Active) 


NC 
No Connection 


INT 
0 = INT Disabled 
1 = INT Enabled 


LOOP 
0 = 
LOOP Disabled 


1 = 
LOOP Enabled 


Bits are Set to Logic "0“. 


modem control inputs (—CTS, -DSR, and 
bits in the IIR register, and an interrupt 
MSR(3) Delta Data Carrier Detect 
-RI) are disconnected. The modem 
(INTRPT) is generated. The MSR is a 
(DRSLD): DRSLD indicates that the 
control outputs (-DTR and —RTS) are 
priority 4 interrupt. The contents of the 
-RSLD input to the serial channel has 
internally connected to the four modem 
Modem Status Register are described in 
changed state since the last time it was 
control inputs. The modem control 
Table 5. Note that the state (high or low) 
read by the CPU. 
output pins are forced to their inactive 
of the status bits are inverted versions of 
MSR(4) Ciear to Send (CTS): Cigar io 
state (high). 
the actual input pins. 
Send (CTS) is ihe status oi the _CTs 


In the diagnostic mode, data transmitted 
MSR(0) Delta Clear to Send (DCTS): 
input from the modem indicating to the 
is immediately received. This allows the 
DCTS displays that the —CTS input to 
serial channel that the modem is ready 
processor to verify the transmit and 
the serial channel has changed state 
to receive data from the serial channel's 
receive data paths of the selected serial 
since it was read last by the CPU. 
transmitter output (SOUT). 
If the serial 
channel. Bits MCR(5) - MCR(7) are 
MSR 1 
D it 
D i 
S i R 
d 
DDSR 
_ 
channel is in loop mode[(MSR(4) = 1], 
permanently set to logic 0. 
Dosig indilaiesihaai as _ei§SIi’i(inpui Hg’ 
MSR(4) is equivalent to --RTS in the 


The MSR provides the CPU with status 
the serial channel has changed state 
MCR‘ 
of the modem input lines from the 
since the last time it was read by the 
MSR(5) Data Set Ready (DSR): Data 
modem or peripheral devices. The MSR 
CPU. 
Set Ready (DSR) is a status of the -DSR 
allows the CPU to read the serial 
.. 
. 
. 
input from the modem to the serial 
channel modem signal inputs by 
_.|i€;;'ini£‘:iriEi:2iee§fii_i?;??h:‘g'i<:igr ui 
channel which indicates that the modem 
accessing the data bus interface of the 
to ihe eriaicharinei has changed Siai: 
is ready to provide received data to the 
ACE in addition to the current status 
imm high to iow since the iasi time ii was 
serial channel receiver circuitry. If the 
information, four bits of the MSR indicate 
read by the CPU_ Low to high transitions 
channel is in the loop mode [MCR(4) -= 
whether the modem inputs have 
_ 
. 
1], MSR(5) is equivalent to the DTR in 
changed since the last reading of the 
on 
RI do not acuvate TERL 
the MCR. 
MSR. The delta status bits are set high 
when a control input from the modem 
°ha"9°$ $1816» a"d '°$°1'°W Wh°"1h° 
TABLE 5. MODEM STATUS REGISTER BITS 
CPU reads the MSR. 


The modem input lines for the channel 
asap on 
are -CTS, -DSR, -RI, and -RLSD. 
MSR(0) 
DCTS 
Delta Clear Te Send 
MSR(4) - MSR(7) are status indications 
MSR(1) 
DDSR 
Delta Data Set Read)! 
of these lines. The status indications 
MSR(2) 
TER| 
Trai|ing Edge of Ring lndicaior 
follow the status of the input lines. If the 
MSR(3) 
DRLSD 
Dena Data Carrier Detect 
modem status interrupt in the Interrupt 
MSR(4) 
_Ci-S 
Cigar To Send 
EblR't' 
bldlER3. 
cI:‘:ngee ofegI:tZriI1sae?rTod(6m[inptIt§igTials 
MSR(5) 
"D88 
Data Set Ready 
will be reflected by the modem status 
MSR(6) 
-8! 
Rie lndieeter 
MSR(7) 
-RLSD 
Receiver Line Signal Detect 
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MSR(6) Ring Indicator (RI): Indicates 
the status of the RI input (pin 39). If the 
channel is in the loop mode (MCR(4) -= 
1), (6) is not connected in the MCR. 


MSR(7) Receive Line Signal Detect 
(RLSD): Receive Line Signal Detect 
indicates the status of the Receive Line 
Signal Detect (-RLSD) input. If the 
channel is in the loop mode (MCR(4)-1), 
MSR(4) is equivalent to OUT2 of the 
MCR. 


The modem status inputs (-RI, -RLSD, 
-DSR, and -CTS) reflect the modem 
input lines with any change of status. 
Reading the MSR register will clear the 
delta modem status indications but has 
no effect on the status bits. The status 
bits reflect the state of the input pins 
regardless of the mask control signals. 
If 
a DCTS, DDSR, TERI, or DRLSD are 
true, and a state change ocxzurs during a 
read operation (—DlSTR), the state 
change is not indicated in the MSR. If 
DCTS, DDSR, TERI, or DRLSD are 
false, and a state change occurs during 
a read operation, the state change is 
indicated after the read operation. 


For LSR and MSR, the setting of status 
bits is inhibited during status register 
read —DlSTR operations. If a status 
condition is generated during a read 
-DISTR operation, the status bit is not 
set until the trailing edge of the read 
-DISTR. 


If a status bit is set during a read 
—DlSTR operation, and the same status 
condition occurs, that status bit will be 
cleared at the trailing edge of the read 
—DlSTR instead of being set again. 


The ACE serial channel contains a 
programmable Baud Rate Generator 
(BRG) that divides the clock (DC to 3.1 
MHz) by any divisor from 1 to 215" (see 
also BRG description). The output 
frequency of the Baud Generator is 16X 
the data rate [divisor # = clock + (baud 
rate x 16)]. Two 8-bit divisor latch 
registers store the divisor in a 16-bit 
binary format. These Divisor Latch 
registers must be loaded during initializa- 
tion. Upon loading either of the Divisor 
Latches, a 16-bit baud counter is 
immediately loaded. This prevents long 
counts on initial load. 


The receiver circuitry in the serial 
channel of the ACE is programmable for 
5, 6, 7, or 8 data bits per character. For 
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words of less than 8 bits, the data is right 
justified to the least significant bit LSB = 
Data Bit 0 [RBR(0)]. Data Bit 0 of a data 
word [RBR(0)] is the first data bit re- 
ceived. The unused bits in a character 
less than 8 bits are output low to the 
parallel output by the serial channel. 


Received data at the SIN input pin is 
shifted into the Receiver Shift Register 
by the 16X clock provided at the CLK 
input. This clock is synchronized to the 
incoming data based on the position of 
the start bit. When a complete character 
is shifted into the Receiver Shift Regis- 
ter, the assembled data bits are parallel 
loaded into the Receiver Buffer Register. 
The DR flag in the LSR register is set. 


Double buffering of the received data 
permits continuous reception of data 
without losing received data. While the 
Receiver Shift Register is shifting a new 
character into the serial channel, the 
Receiver Buffer Register is holding a 
previously received character for the 
CPU to read. Failure to read the data in 
the RBR before complete reception of 
the next character result in the low of the 
data in the Receiver Register. The OE 
flag in the LSR register indicates the 
overrun condition. 


RBR Bits 0 through 7: 


RBR(0) 
Data Bit 0 


THRw) 
THRU) 
THRQ) 
THRQ) 
THRM) 
THR6) 
THR@) 
THRU) 


DmaBt0 
DmaB11 
DmaBR2 
DmaB13 
DmaBR4 
DmaBt5 
Data B't 6 
Data Bit 7 


Scratchpad Register is an 8-bit Readl 
Write register that has no effect on either 
channel in the ACE. 
It is intended to be 
used by the programmer to hold data 
temporarily. 


SCR Bits 0 through 7: 


SCR(0) 
Data Bit 0 
scRu) 
scR@) 
SCR6) 
SCRM) 
SCR6) 
SCR@) 


Data Bit 1 
Data Bit 2 
DmaBh3 
DmaBh4 
DmaBh5 
DmaBh6 


RBRU) 
RBRQ) 
RBRQ) 
RBRM) 
RBR6) 
ReR@) 
RBRU) 


DmaBH1 
DmaBH2 
DmaBh3 
DmaBh4 
DmaBh5 
DmaBH6 
DmaBh7 


The Transmitter Holding Register (THR) 
holds parallel data from the data bus 
(D0-D7) until the Transmitter Shift 
Register is empty and ready to accept a 
new character for transmission. The 
transmitter and receiver word length and 
number of stop bits are the same. If the 
character is less than eight bits, unused 
bits at the microprocessor data bus are 
ignored by the transmitter. 


Data Bit 0 (THR(0)) is the first serial data 
bit transmitted. The THRE flag (LSR(5)) 
reflect the status of the THR. The TEMT 
flag (LSR(5)) indicates if both the THR 
and TSR are empty. 


THR Bits O through 7: 
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SCR(7) 
Data Bit 7 


INTERRUPTS 
The Interrupt Identification Register (IIR) 
in the serial channel of the ACE has 
interrupt capability of interfacing to 
current microprocessors. In order to 
minimize software overhead during data 
character transfers, the serial channel 
prioritizes interrupts into four levels. The 
four levels of interrupt conditions are as 
follows: 


1. Receiver Line Status (priority 1) 


2. Received Data Ready (priority 2) 


3. Transmitter Holding Register Empty 
(priority 3) 


4. Modem Status (priority 4) 


Information indicating that a prioritized 
interrupt is pending and the type of 
interrupt is stored in the Interrupt 
Identification Register (IIR). When 
addressed during chip select time, the 
IIR indicates the highest priority interrupt 
pending. No other interrupts are 
acknowledged until the interrupt is 
serviced by the CPU. The contents of 
the IIR are indicated in Table 6 and are 
described below: 


llR(O): llR(0) can be used in either a 
hard-wired prioritized or polled environ- 
ment to indicate whether an interrupt is 
pending. When llR(0) is low, an interrupt 
is pending, and IIR contents may be 
used as a pointer to the appropriate 
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TABLE 6. INTERRUPT IDENTIFICATION REGISTER 


Interrupt ldentlflcatlon 
Interrupt Set And Reset Functions 


Prlorlty 
Interrupt 
Interrupt 
Interrupt 


X 
X 
1 
None 
None 


1 
1 
0 
First 
Receiver 
OE, PE 
LSR Read 
Line Status 
FE, or BI 


1 
0 
0 
Second 
Received Data 
Received Data 
RBR Read 
Available 
Available 


0 
1 
0 
Third 
THRE 
THRE 
IIR Read if THRE is the 
Interrupt Source or THR Write 


0 
0 
0 
Fourth 
Modem Status 
-CTS, -DSR 
MSR Read 
-RI, -RSLD 


X = Not Defined. 
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TABLE 7. SERIAL CHANNEL ACCESSIBLE REGISTERS 


Register 
Register Blt Number 


VL16C450 - VL82C50A - VL8 


RBR 
Data 
(Read Only) 
Bit 7 
(MSB) 


THR 
Data 
(Write Only) 
Bit 7 


DLL 
Bit 7 


DLM 
Bit 15 


IER 
0 


IIR 
O 
(Read Only) 


LCR 
(DLAB) 
Divisor 
Latch 
Access 
Bit 


MCR 
0 


LSR 
0 


Data 
Bit 6 


Data 
Bit 6 


Bit 6 


Bit 14 


O 


0 


Set 
Break 


Data 
Bit 5 


Data 
Bit 5 


Bit 5 


Bit 13 


0 


O 


Stick 
Parity 


0 
0 


Data 
Bit 4 


Data 
Bit 4 


Bit 4 


Bit 12 


0 


O 


(EPS) 
Even 
Parity 
Select 


Loop 


(TEMT) 
(THRE) 
(Bl) 
Transmitter 
Transmitter 
Break 
Empty 
Holding 
Register 
Empty 


MSR 
(DCD) 
(RI) 
(DSR) 
Data 
Ring 
Data 
Carrier 
Indicator 
Ready 
Detect 
Set 


SCR 
Bit 7 
Bit 6 
Bit 5 


‘LSB Data Bit O is the first bit transmitted or received. 


(CTS) 
Clear 
to 
Send 


Bit 4 
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Data 
Bit 3 


Data 
Bit 3 


Bit 3 


Bit 11 


(EDSSI) 
Enable 
Modem 
Status 
Interrupt 


O 


(PEN) 
Parity 
Enable 


Out 2 


(FE) 
Framing 
Interrupt 
Error 


Data 
Bit 2 


Data 
Bit 2 


Bit 2 


Bit 10 


(ELSU 
Enable 
Receiver 
Line 
Status 
Interrupt 


Interrupt 
ID 
Bit (1) 


(STB) 
Number 
of Stop 
Bits 


Out 1 


(PE) 
Parity 
Error 


(DRSLD) 
(TERI) 
Deha 
Receive 
Trailing 
Edge 
Line Signal 
Ring 
Detect 
Indicator 


Bit 3 
Bit 2 


Data 
Bit 1 


Data 
Bit 1 


Bit 1 


Bit 9 


(ETBEU 
Enable 
Transmitter 
Holding 
Register 
Empty 
Interrupt 


Interrupt 
ID 
Bit (0) 


(WLSB1) 
Word 
Length 
Select 
Bit 1 


(RTS) 
Request 
To 
Send 


(OE) 
Overrun 
Error 


(DDSR) 
Delta 
Data 
Set 
Ready 


Bit 1 


Data 
Bit 0 
(LSB)‘ 


Data 
Bit 0 


B110 


Bit 8 


(ERBFI) 
Enable 
Received 
Data 
Available 
Interrupt 


"0" 1F 
Interrupt 
Pending 


(WLSBO) 
Word 
Length 
Select 
Bit 0 


(DTR) 
Data 
Terminal 
Ready 


(DR) 
Data 
Ready 


(DCTS) 
Deha 
(Near 
to 
Send 


Bit O 


2C50 
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interrupt service routine. When llR(0) is 
high, no interrupt is pending. 


llR(1) and llR(2) are used to identify the 
highest priority interrupt pending as 
indicated in Table 6. 


llR(3) - llR(7): These five bits of the IIR 
are logic 0. 


The Interrupt Enable Register (IER) is a 
Write register used to independently 
enable the four serial channel interrupts 
which activate the interrupt (INTRPT) 
output. All interrupts are disabled by 
resetting lER(0) - lER(3) of the Interrupt 
Enable Register. Interrupts are enabled 
by setting the appropriate bits of the IER 
high. Disabling the interrupt system 
inhibits the Interrupt Identification 
Register and the active (high) INTRPT 
output. All other system functions 
operate in their normal manner, including 
the setting of the Line Status and Modem 
Status Registers. The contents of the 
Interrupt Enable Register is described in 
Table 7 and below: 


lER(0): When programmed high lER(0) 
=- Logic 1), IER(1) enables the Received 
Data Available interrupt. 


IER(1): When programmed high (IER(1) 


-= Logic 1), IER(1) enables the Transmit- 
ter Holding Register Empty interrupt. 


lER(2): When programmed high (lER(2) 
= Logic 1), lER(2) enables the Receiver 
Line Status interrupt. 


lER(3): When programmed high (lER(3) 
= Logic 1), lER(3) enables the Modem 
Status Interrupt. 


lER(4) - lER(7): These four bits of the 
IER are logic 0. 


TRANSMITTER 
The serial transmitter section consists of 
a Transmitter Holding Register (THR), 
Transmitter Shift Register (TSR), and 
associated control logic. The Transmit- 
ter Holding Register Empty (THRE) and 
Transmitter Shift Register Empty (TEMT) 
are two bits in the Line Status Register 
which indicate the status of THR and 
TSR. To transmit a 5- to 8-bit word, the 
word is written through D0-D7 to the 
THR. The microprocessor should 
perform a write operation only if THRE is 
high. The THRE is set high when the 
word is automatically transferred from 
the THR to the TSR during the transmis- 
sion of the start bit. 


When the transmitter is idle, THRE and 
TEMT are high. 
The first word written 
causes THRE to be reset to 0. After the 
transfer, THRE returns high. TEMT 
remains low for at least the duration of 
the transmission of the data word. If a 
second character is transmitted to the 
THR, the THRE is reset low. Since the 
data word cannot be transferred from the 
THR to the TSR until the TSR is empty, 
THRE remains low until the TSR has 
completed sending the word. When the 
last word has been transmitted out of the 
TSR, TEMT is set high. 
THRE is set 
high one THR to TSR transfer time later. 


RECEIVER 
Serial asynchronous data is input into 
the SIN pin. The idle state of the line 
providing the input into SIN is high. A 
start bit detect circuit continually 
searches for a high to low transition from 
the idle state. When the transition is 
detected, a counter is reset, and counts 
the 16X clock to 7 1/2, which is the 
center of the start bit. The start bit is 
valid if the SIN is still low at the mid-bit 
sample of the start bit. Verifying the start 
bit prevents the receiver from assem- 
bling a false data character due to a low 
going noise spike on the SIN input. 


The Line Control Register determines 
the number of data bits in a character 
(LCR(O), LCR(1)), number of stop bits 
LCR(2), if parity is used LCR(3), and the 
polarity of parity LCR(4). Status for the 
receiver is provided in the Line Status 
Register to the Receiver Buffer Register,» 
the Data Received indication in LSR(O) is 
set high. The CPU reads the Receiver 
Buffer Register through DO-D7. This 
read resets LSR(O). If D0-D7 are not 
read prior to a new character transfer 
from the RSR to the RBR, the overrun 
error status indication is set in LSR(1). 
The parity check tests for even or odd 
parity on the parity bit, which precedes 
the first stop bit. If there is a parity error, 
the parity error is set in LSR(2). There is 
circuitry which tests whether the stop bit 
is high. If it is not, a framing error 
indication is generated in LSR(3). 


The center of the start bit is defined as 
clock count 7 1/2. If the data into SIN is 
symmetrical square wave, the center of 
the data cells will occur within i3.125% 
of the actual center, providing an error 
margin of 46.875°/e. The start bit can 


begin as much as one 16X clock cycle 
prior to being detected. 


BAUD RATE GENERATOR (BRG) 
The BRG generates the clocking for the 
UART function, providing standard ANSI! 
CCITT bit rates. The oscillator driving 
the BRG is provided by an external clock 
into CLK. 


The data rate is determined by the 
Divisor Latch registers DLL and DLM 
and the external frequency. The bit rate 
is selected by programming the two 
divisor latches, Divisor Latch Most 
Significant Byte and Divisor Latch Least 
Significant Byte. Setting DLL = 1 and 
DLM -= 0 selects the divisor to divide by 1 
(divide by 1 gives maximum baud rate 
for a given input frequency at the CLK 
input). 


The BRG can use any of three different 
popular frequencies to provide standard 
baud rates. These frequencies are 
1.8432 MHz, 2.4576 MHz, and 3.072 
MHz. With these frequencies, standard 
bit rates from 50 to 38.5k bps are 
available. Tables 8, 9, and 10 illustrate 
the divisors needed to obtain standard 
rates using these three crystal frequen- 
cies. 


MASTER RESET 
After power up, the ACE MR input 
should be held high for one microsecond 
to reset the ACE circuits to an idle mode 
until initialization. A high on MR causes 
the following: 


1. Initializes the transmitter and receiver 
internal clock counters. 


2. Clears the Line Status Register 
(LSR), except for Transmitter Shift 
Register Empty (TEMT) and Transmit 
Holding Register Empty (THRE), 
which are set. The Modem Control 
Register (MCR) is also cleared. All of 
the discrete lines, memory elements 
and miscellaneous logic associated 
with these register bits are also 
cleared or turned off. The Line 
Control Register (LCR), Divisor 
Latches, Receiver Buffer Register, 
Transmitter Buffer Register are not 
effected. 


Following removal of the reset condition 
(Reset low), the ACE remains in the idle 
mode until programmed. 
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A hardware reset of the ACE sets the 
While the control register can be written 
completely known state without a system 
THRE and TEMT status bit in the LSR. 
in any order, the IER should be written to 
reset. Such a reset consists of writing to 
When interrupts are subsequently 
last because it controls the interrupt 
the LCR, Divisor Latches, and MCR 
enabled, and interrupt occurs due to 
enables. Once the serial channel is 
registers. The LSR and RBR registers 
THRE. 
programmed and operational, these 
should be read prior to enabling inter- 
A summary of the eect O‘ a reset on the 
registers. can be updated any time the 
rupts in order to clear out any residual 
ACE is given in Table 11_ 
ACE_S.8fl&| channel IS not transmitting or 
data or status bits which may be invalid 
receiving data. 
PROGRAMMING 
Th 
t 
I 
. 
I 
. 
dt 
The serial channel of the ACE is pro- 
ehcon Fol slggna Srreguwe 
Io ac.cesS 
grammed bythe Control register LCR’ 
eac seria c anne s interna registers 
IER, DLL and DLM, and MCR. These 
a‘° S“°‘”" b°'°‘”- 
control words define the character 
SOFTWARE RESET 
length, number of stop bits, parity, baud 
A software reset of the serial channel is 
rate, and modem interface. 
a useful method for returning to a 


for subsequent operation. 


TABLE e. BAUD RATES (1.8432 MHz CLOCK) 


Deslred 
Dlvlsor Used 
Percent Error 
Baud Rate 
Difference Between 
Deslred and Actual 


50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 
56000 


2304 
1536 
1047 
857 
768 
384 
192 
96 
64 
58 
48 
32 
24 
16 
12 
6 
3 
2 


0.026 
0.058 


0.69 


2.86 
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TABLE 9. BAUD RATES (2.4576 MHz CLOCK) 


Desired 
Divisor Used 
Percent Error 
Baud Fiate 
Difference Between 
Desired and Actual 


50 
75 
110 
134£5 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 


50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 
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3072 
2048 
1396 
1142 
1024 
512 
256 
128 
85 
77 
64 
43 
32 
21 
16 
8 
4 


3840 
2560 
1745 
1428 
1280 
640 
320 
160 
107 
96 
80 
53 
40 
27 
20 
10 
5 


VL1 


(L026 
0.0007 


(1392 
(L260 


(L775 


1.587 


TABLE 10. BAUD RATES (3.072 MHZ CLOCK) 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


(L026 
(1034 


(I312 


(1628 


L23 
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TABLE 11. MASTER RESET 


Reset Control 
Register/Signal 


interrupt Enable Register 
Interrupt identification 
Register 
Line Control Register 
MODEM Control Register 
Line Status Register 
MODEM Status Register 


sour 
lntrpt (nova Eris) 
lntrpt (RCVR Data Ready) 
lntrpt (THRE) 
lntrpt (Modem Status Changes) 
-43m2 
-RTS 
-DTR 
-Ou 


® 
. 


Reset 
Reset 


Reset 
Reset 
Reset 
Reset 


Reset 
Read LSR/Reset 
Read RBR/Reset 
Read llR/Write THR/Reset 
Read MSR/Reset 
Reset 
Reset 
Reset 
Reset 


VL16C450 


>pmm> 


High 
Low 
Low 
Low 
Low 
High 
High 
High 
High 


VL82C50A 
VL82C50 


Reset 


I Bits Low (0-3 forced and 4-7 permanent) 
't 0 is High 
Bits 1 and 2 Low 
its 3—7 are Permanently Low 


i Bits Low 


I Bits Low 
A'l Bits Low, Except Bits 5 and 6 are High 
Bits 0-3 Low 
Bits 4-7 Input Signal 
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AC CHARACTERISTICS: TA = o°c to +1o<>c vcc = s v 15% Note 1 


VL1 C450 
VL82C50A 
VL82C50 


Symbol 
Parameter 


tAW 
Address Strobe Width 


tAS 
Address Setup Time 


tAH 
Address Hold Time 


tCS 
Chip Select Setup Time 


E 
E 
-E 
1-K 
2@-E 
tCH 
Chip Select Hold Time 
W 
E-"E 
*“° 
—@-@—§ 


RC 
E-_—B 
mmwt-E-E_EB 
W@WWW—E—E-HE 


Z 
DataDeIay 
~IWWW—_ 
w@W@-H-E-B 
=w<= 
m—m—m—u 
WC 
Write Cycle = tAW’ + tDOW 
755 
755 
+ tWC 
">8 
Il—EI-Q-E 
‘DH 
IIIEIKIE 
, 
Chip Select Output Delay IMIEIEB 
mp‘, 
Address Hold Time from 
-DISTR/DISTR 
, 
Chip Select Hold 'l'ime from 
is 
___ 
Um, 
-DISTR/DISTR Delay from 
Address 
, 
—DlSTR/DISTR Delay from —_—B 
WA, 
Address Hold Time from 
‘ 
-oosrn/oosrn 
, 
Chip Select Hold ‘lime from 
“~08 
-eeeeeeee 
___ 
—DOSTR/DOSTR Delay 
W 
___B 
-DOSTR/DOSTR Delay fro 
W 
__-B 
‘WW 
Imi- 
“H 
E—E!IH—- 


Notes: 1. All timings are referenced to valid 0 and valid 1. (See AC TEST POINTS.) 
2. Applicable only when ADS is tied Low. 
3. Charge and discharge time is determined by VOL, VOH and the external loading. 
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Conditions 


100 pF Load 
Note 3 


100 pF Load 


100 pF Load 
Note 3 


100 pF Load 


Note 2 


Note 2 


Note 2 


Note 2 


Note 2 


Note 2 


Note 2 


Note 2 


Extemai Clock 
(3.1 MHz Max) 
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AC CHARACTERISTICS (Cont.): TA = o<>c to + 70°C, vcc = s v 15% (Note 1) 
VL16C450 
VL82C50A 
VL82C50 


Symbol 
Parameter 
Conditions 


E 
ID3 
2 


Q-l 
—‘N 


IO 


<§ 


(D 


Transmitter 


Delay from Rising Edge of 
tHR1 
-DOSTR/DOSTR (WR THR) 
175 
N/A 
100 pF Load 
to Reset lnterrut 


Delay from Falling Edge of 
tHR2 
—DOSTR/DOSTR (WR THR) 
N/A 
N/A 
1000 
100 pF Load 
to Reset interrut 
“RS 
Delay from Initial INTR 
-BAUDOU 
Rese in erru 
CYCLES 
t 
t 
pt 


Delay from initial Write to 
-BAUDOU 
interrupt 
CYCLES 


Delay from Stop to Next 
‘SS 
Start 


Delay from Start Bit Low to 
AUDOU 
Interrupt (THRE ) High 
CYCLES 


Delay from —D|STR/DISTR 
(RD IIR) to Reset interrupt 
1000 
1000 
100 pF Load 
(THRE) 
Modem Control 


Delay from —DOSTR/DOSTR 
tMDO 
(WR MCR) to Output 
100 pF Load 


‘SIM 
Delay to Set interrupt from 
100 pF Load 
MODEM input 


Delay to Reset interrupt from 
WM 
-DISTR/DISTR (RS MSR) 
‘°°° 


Baud Generator 


100 pF Load 


Baud Divisor 


Baud Output Negative 
tBLD 
Edge Dewy 
100 pF Load 


tBHD 
Baud Output Positive 
100 pF Load 
Edge Delay 


_ 
M 
r 
I 
Baud Output Down Time 
5 
‘120 SF LCZJ2 


, 
fX - 2 MHz, +2, 
tHW 
Baud Output Up Time 
100 pp Load 


Delay from RCLK to 
-B-I 
Delay from Stop to Set IIIIIIIII 
Delay from 
DISTR/DISTR 
IRINT 
(RD RBR/RDLSR) t0 Reset 
1 
its 
100 pF Load 
interrupt 


N019: 1. All timings are referenced to valid 0 and valid 1. 
(See AC TEST POINTS.) 
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TIMING DIAG RAMS 
READ CYCLE 


tAW 
’ 


ADS 


tAS-D 
A2, A1_ A0 
VALID * 
RA. 
"°”-°S"°S° 
IWE 
I‘ 


CSOUT ‘ 
‘Ros.’ 
\- 
I icsR' 


WWR 
wjb 
I 
4 
OR 
V 
I?I[ 
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RECEIVER 


’ 
VL16C450 - VL82C50A - VL82C50 


RCLK 
I 
I 
I 
I 
I 
I 
I<—-—-——k a cu<s —-1-—-—>| |<- isco 


SAMPLE 
CLK 
I 
I 


SIN 
(RECEIVER 
INPUT 
START 
DATA ens is-a) 
@ 
STOP 


DATA) 


INTERRUPT 
(DATA READY on 
ncvnsnn) 


-DISTR/DISTR 
(NOTE 2) 


IREAD REC 
DA A BUFFER 
OR RDLSR) 


TRANSMITTER 


SERIAL 
OUT (sour) 


INTERRUPT 
(THRE) 


-DOSTR/DOSTR 
(wn THR) 
(NOTE1) 


-DISTR/DISTR 
(no IIR) 
(NOTE 2) 


Notes: 1. See WRITE "Fming Diagram 
2. See READ Timing Diagram. 


START 
STAR 
DATA 15'”) 
. STOP (1-2) 
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—*i 
I 


ACTIVE 


T 


ms 
PARITY 
——> 
4—- ISTI 


‘HR 
tHR 
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WRITE CYCLE 
tAW 
-ADS 


tAS 


A2, A1, A0 
VALID 


-CS2, CS1, CSO 
éii! 


VL16C450 
VL82C50A 
VL82C50 


4-tAH 
\ 
/_"""i_"_"_'i"_""'_ 


tWA‘ 


\ 
/“—-_"""ii"'—"i""'___ 
icsc'_->I 
iwcs* 
—— 
_'_'__"'T 
csouT 
\_. ._ ._ ._ ._ ._ ..... ._ _ ._.__..._...._._.._......._._.._._.._......_._... 


tCSW‘ 
tAW‘ 
. 
wc 


—DOSTR/DOSTR 


tDOW'—>I4ii— tWCl 


\__._i)‘ 
on 
V 
—DISTR/DISTR 
>$ ACTIVE 


DATA 
VALID DATA 
oo-07 


MODEM CONTROLS 


—DOSTR/DOSTR 
(we MCR) 


-—RTS, -DTR 
—OUT1 , -OUT2 


-CTS, —DSA, —DCD 


INTERRUPT 


—DISTR/DISTFI 
(RD MSR) 


—RI 


IDS 
IDH 
l'—'l'—'i 


IMDQ 
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AC TESTTNG INPUT/OUTPUT WAVEFORMS 


EXTERNAL CLOCK INPUT (3.1 MHz MAXIMUM) 
AC TEST POINTS 
4-> 
tXH 


XTAL1 
2.0 V 
2.0 V 


0.8 v 
0.9 v 


4- tXL -> 


Note: 
All timings are referenced to valid 0 and valid 1. 


TEST CIRCUIT 


IT- 


2.54 V 


Device Under Test 
680 Q 


82 pF?' 


Includes Scope and Jig 
Capacitance 
'2‘ 
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BASIC CONFIGURATION 
VL16C450, VL82C50A, VL82C50 
- 
no-07 


D0-D7 
SOUT 


-MEMR OR -I/OR 


CPU 
BUS 
—MEMW OR -I/OW 
-DOSTR 
-RTS 
we 
- 
INTRPT 
-DTR 


RESETIII 


MR 
-DSR 


VL1 6C45O 
A0 
VL82C50A 
—DCD 
VL82C50 
A1 
—CTS 


I\)-'~ 
C) 
A2 
-RI 


-ADS 
XTAL1 
= DOSTR 


VL16C450 - VL82C50A 
VL82C50 


EIA 
-DISTR 
SIN 
DQIVERS 


DISTR 
RP 
ii 


-cs2 
XTAL2 
cs1 
RX2 
- 
-BAUD 
1 
cso 
—OUT 


RCLK 


TYPICAL COMPONENT VALUES 


°'Ys"=" 
K 
°2 
3.072 MHZ 
1 MQ 
1.5 KQ 
10 - so pF 
40 - so pF 
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ABSOLUTE MAXIMUM RATINGS 
Ambient Operating 
Temperature 
-10°C to + 70°C 


Storage Temperature -65°C to + 150°C 


Supply Voltage to 
Ground Potential -0.5 V to VCC + 0.3 V 


Applied Output 
Voltage 
-0.5 V to VCC + 0.3 V 


Applied Input 
Voltage 
-0.5 V to + 7.0 V 


Power Dissipation 
500 mV 


Stresses above those listed may cause 
permanent damage to the device. These 
are stress ratings only, functional 
operation of this device at these or any 
other conditions above those indicated in 


this data sheet is not implied. Exposure 
to absolute maximum rating conditions 
for extended periods may affect device 
reliability. 


DC CHARACTERISTICS: TA = 0° to +1o=c, vcc = s v 1 5% 


VL1 6C45O 
VL82C50A 


Symbol 


VILX 


VIHX 


Parameter 


C 


C 


lock Input Low Voltage 


lock input High Voltage 


Input Low Voltage 


Input High Voltage 


VOL 


VOH 


Output Low Voltage 


t High 


S5IF‘ 


Outpu 
Voltage 


ICC 
Average Power Supply 
(Ave) 
Current (VCC) 


input Leakage 
:1: 
:I: 
5: 


6:'__ 
r- 
—L 
Q-Lo0 


I“o 


Q-AQ-Loo 
T:T: 
Clock Leakage 
1; 
i 
:l: 


IOZ 
Three-State Leakage 


VILMR 
MR Schmitt VIL 


VIHMR 
MR Schmitt VIH 


VL82C5 


01 
OU1 


<<OO 


4*in01 


O 
< -0 


4>‘U,o‘U, 


<O 


2 


10 
mA 


0 


Conditions 


VCC 


IOL 1.6 mA on All 


IOH = -1.0 mA 


VCC -= 5.25 V, No 
Loads on SIN , -DSR 
-RLSD, -CTS, —DCD. 
—RI = 2.0 V. All Other 
Inputs = 0.8 V. Baud 
Rate Generator at 
4MHz. Baud Rate at 
56K. 


VCC = 5.25 V 
VSS = 0 V 
All Other Pins Floating 


VIN = 0 V, 5.25 V 


VCC = 5.25 V 
VSS =. 0 V 
VOUT = 0 V, 5.25 V 
1I Chip Deselected 
2 
Chip and Write 
Mode selected 


Note: 
—lNlT, -AFD, -STB, and -SLIN are collector output pins that each have an internal pull-up resistcr (2.5K Q - 3.5K Q) to 
VCC. This will generate a maximum of 2.0 mA of internal IOL. in addition to this internal current, each pin will sink at 
least 10 mA, while maintaining the VOL specification of 0.4 V Max. 
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FEATURES 
- IBM PC/AT-compatible 


PARALLEL/ASYNCHRONOUS 
COMMUNICATIONS ELEMENT 
DESCRIPTION 
The VL16C451 is an enhanced version 


- VL16C450 with on-board Centronix 
°' "‘° °°P“'t?’ VL‘|6C"5° ‘§"I’>‘*‘E°“f|E‘h"°“s 
primer menace 
communica ions eement( 
_ 
). 
e 
serial channel performs serial-to-parallel 
' C°mPIeI9|Y Pln‘ and Upward-¢°mP8F 
conversion on data characters received 
ibie with the dual serial channel 
VL16C452 
. 


- independent control of transmit, 
receive, line status and data set 
interrupts 


- Individual modem control signals 


- Programmable serial interface 
characteristics: 
- 5-,6-,7- or 8-bit characters 
— Even-, odd- or no-parity bit 
generation and detection 


from peripheral devices or modems, and 
parallel-to-serial conversion on data 
characters transmitted by the CPU. The 
complete status of the Paral|el/Asyn- 
chronous Communications Element 
(P/ACE) can be read at any time during 
functional operation by the CPU. The 
information obtained includes the type 
and condition of the transfer operations 
being performed, and error conditions. It 
is fully pin- and upward-compatible with 
the dual serial channel VL16C4S2. The 


occupies pins that are VCC, GND, or 
- Three-state TTL drive for the data and 
N_C_ (not connected) on the vL16C451_ 
control bus 


The VL16C451 also provides the user 
with a fully bidirectional parallel data port 
that fully supports the parallel Centronics 
type printer. This port allows information 
received from either serial communi- 
cation port to be printed from the P/ACE. 
The parallel port, together with the serial 
port, provide IBM PC/AT-compatible 
computers with a single device to serve 
the two system ports. 


A programmable baud rate generator is 
included that can divide the timing 
reference clock input by a divisor 
between 1 and (215 -1). 


The VL16C451 is housed in a 
68-pin plastic leaded chip carrier. 


PIN DIAGRAM 
BLOCK DIAGRAM 


VL16C451 


GND 
GND 
CLK 
GND 
-ACK 
BUSY 
VCC 
GND 


0.2m.— 
~1.gc>.—' 01.2 :- 
u 
N 


‘-O 
~.c. I 1o 
~.c. I 11 


0| VCCI-LPTOEI PE ISLCTI -ERRIGND 
.0150 
II IIII IIII IIIIII Ill. Ill. 
_Q3RQ 
as 67 ea as e4 ea s2 s1 
-RLSN 
60 I 
N.C. 
_RD 
59 I INT2 
SINO 


-RTSO 
—DTRO 
SOUTO 
INTO 


UART 
#1 


N.C. I 


GND I 
oso I 


D81 I 
oez I 
oaa I 


DB4 I 
oes I 
oea I 
oer I 
cuo I 
vcc I 
-RTSO l 
-orno I 


SOUTO I 


12 


13 


14 


15 


16 


17 


18 


19 


20 


21 
Z 


23 


24 


25 


26 


4.59' 2 


TOP VIEW 


-CSOA1 
0 
G 
GND 
gnu 
I83!: ‘ls 
‘I8 gl I: 


Lgl 
QLIS 
glsgalsal8lsOEI: 


ls la 
ZO 


sa 
s1 
se 
ss 
54 
as 
sz 
s1 
>I 
40ll 
4a 
47 
MI 
il 
Mil 


__sUN 
-CSO 


-INIT 
DBO - DB7 
-AFD 
45T8 
GND 


PDO 


PD1 
P02 
P03 
P04 
P05 
PD6 


PD7 


INTO 


BOO 


A0 - A2 
—IOW 
-IOR 
-RESET 
CLK 


—ERR 
SLOT 
BUSY 
PE 
-ACK 
—LPTOE 
-CS2 


8 


SELECT 
AND 
CONTROL 
LOGIC 


ORDER INFORMATION 
Part 
Maximum 
Number 
Package 


VL16C451-OC Plastic Leaded Chip Carrier (PLCC) 


PARALLEL 
PORT 


Note: Operating temperature range is 0°C to +70°C. 


BDO 


PIX) - PD7 
—INIT 
-AFD 
—STB 
-SLIN 
lNT2 
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SIGNAL DESCRIPTIONS 
Slgnal 
Pln 
Name 
Number 
Slgnal 
Descrlptlon 


-—IOFi 
37 


—lOW 
36 


DBO-DB7 
14-21 


A0, A1, A2 
35, 34, 33 


CLK 
4 


SOUTO, 
26 


-CTSO 
28 


DSRO 
31 


DTRO 
25 


-RTSO 
24 


-RIO 
30 


-LPTOE 
1 


SINO 
41 


Input/Output Read Strobe - This is an active low input which causes the serial channel to 
output data to the data bus (DBO-DB7). The data output depends upon the register 
selected by the address inputs A0, A1, A2. Chip Select 0 (-CSO) selects the UART and 
Chip Select 2 (-CS2) selects the line printer port. 


Input/Output Write Strobe - This is an active low input which causes data from the data 
bus (DBO-DB7) to be input to the UART or to the parallel port. The data input depends 
upon the register selected by the address inputs A0, A1, A2. The chip select inputs 
(—CSO and -CS2) enable the UART and the parallel port (respectively). 


Data Bits DBO-DB7 - The Data Bus provides eight, three-state I/O lines for the transfer of 
data, control and status information between the VL16C451 and the CPU. These lines are 
normally in a high-impedance state except during read operations. D0 is the least signifi- 
cant bit (LSB) and is the first serial data bit to be received or transmitted. 


Address Lines A0-A2 - The address lines select the internal registers during CPU bus 
operations. See Table 1 for the decode of the serial channels, Table 11 for the decode of 
the parallel line printer port. 


Clock Input - The external clock input to the UART baud rate divisor 


Serial Data Output - This line is the serial data output from the UART‘s transmitter 
circuitry. A mark (1) is a logic "one" (high) and space (O) is a logic ‘zero’ (low). SOUTO is 
held in the mark condition when the transmitter is disabled, Reset is true, the Transmiter 
Register is empty, or when in the Loop Mode. 


Clear to Send lnput - The logical state of the -CTS pin is reflected in the CTS bit of the 
(MSR) Modem Status Register [CTS is bit 4 of the MSR, written MSR (4)1 of the UART. A 
change of state of the -CTS pin, since the previous reading of the MSR causes the 
setting of DCTS [MSR(0)] of the Modem Status Register. When the -CTS pin is low, the 
modem is indicating that data on SOUTO can be transmitted. 


Data Set Ready Input - The logical state of the DSRO pin is reflected in MSR(5) of the 
Modem Status Register. DDSR [MSR(1)] indicates whether the DSRO pin has changed 
state since the previous reading of the MSR. When the DSRO pin is low, the modem is 
indicating that it is ready to exchange data with the UART. 


Data Terminal Ready Output - The DTRO pin can be set (low) by writing a logic 1 to 
MCR(O), Modem Control Register bit 0 of the UART. This signal is cleared (high) by 
writing a logic 0 to the DTR bit [MCR(0)] or whenever a reset occurs. When active (low), 
the DTRO pin indicates to the DCE that the UART is ready to receive data. 


Request to Send Output - The -RTSO signal is an output on the UART used to enable the 
modem. The -RTSO pin is set low by writing a logic 1 to MCR(1) bit 1 of the UART‘s 
Modem Control Register. The -RTSO pin is reset high by Reset. A low on the -RTSO pin 
indicates to the DCE that the UART has data ready to transmit. ln half duplex operations, 
-RTSO is used to control the direction of the line. 


Ring Indicator Input - When low, -RIO indicates that a telephone ringing signal has been 
received by the modem or data set. The -RIO signal is a modem control input whose 
condition is tested by reading MSR(6) (RI) of the UART. The Modem Status Register 
output TERI [MSR(2)] indicates whether the RI input has changed from high to low since 
the previous reading of the MSR. lf the interrupt is enabled [lER(3)-1] and —Rl0 changes 
from a high to low, an interrupt is generated. 


Parallel Data Output Enable - When low, this signal enables the Write Data Register to 
the PDO - PD7 lines. A high puts the PDO - PD7 lines in the high-impedence state 
allowing them to be used as inputs. -LPTOE is usually tied low for line printer operation. 


Serial Data Input - The serial data input moves information from the communication line 
or modem to the VL16C451 receiver circuits. A mark (1) is high, and a space (0) is low. 
Data on serial data inputs is disabled when operating in the loop mode. 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrl tlon 


-RLSDO, 


—RESET 


INTO 


-CSO, -CS2 


BDO 


PDO-PD7 


-STB 


-AFD 


-INIT 


—SLlN 


lNT2 


-ERROR 


SLCT 


BUSY 


PE 


-ACK 


VCC 


GND 


29 


39 


45 


32, 38 


44 


53-46 


55 


56 


57 


58 


59 


63 


65 


66 


67 


68 


3, 23, 40, 64 


2, 5-9, 13, 22, 27, 
42, 43, 54, 61, 62 


P 


Receive Line Signal Detect - When low, the -RLSD output indicates that the data carrier 
has been detected by the modem or data set. -RLSD is a modem input whose condition 
can be tested by the CPU by reading MSR(7) (RLSD) of the Modem Status Register. 
MSR(3) (DRLSD) of the Modem Status Register indicates whether the -RLSD input has 
changed since the previous reading of the MSR. -RLSD has no effect on the receiver. If 
the -RLSD changes state with the modem status interrupt enabled, an interrupt occurs. 


Reset - When low, the reset input forces the VL16C451 into an idle mode in which all 
serial data activities are suspended. The Modem Control Register (MCR) along with its 
output is cleared. The Line Status Register (LSR) is cleared except for the THRE and 
TEMT bits, which are set. All functions of the device remain in an idle state until pro- 
grammed to resume serial data activities. 


Serial Channel Interrupt Output - This three-state output is enabled by the MCR bit 2. 
The serial channel interrupt goes active (high) when one of the following interrupts has 
an active (high) condition and is enabled by the Interrupt Enable Register of the serial 
channel: Receiver Error flag, Received Data Available, Transmitter Holding Register 
Empty, and Modem Status. The interrupt is reset low upon appropriate service or a reset. 


Chip Selects - Each Chip Select input acts as an enable for the write and read signals 
for its channel. -CSO enables the serial port, while -CS2 enables the the signals to the 
line printer port. 


Bus Buffer Output - This active high output is asserted when this serial channel or the 
parallel port is read. This output can be used to control the system bus driver device 
(74Ls24sy 


Parallel Data Bits (0-7) - These eight lines provide a byte-wide input or output port to the 
system. The eight lines are held in a high-impedance state when -LPTOE is held in the 
high state. 


Line Printer Strobe - This open-drain line provides communication between the 
VL16C451 and the line printer. When it is active low, it provides the line printer with a 
signal to latch the data currently on the parallel port. 


Line Printer Autofeed - This open-drain line provides the line printer with an active low 
signal when continuous form paper is to be autofed to the printer. 


Line Printer Initialize: This open-drain line provides the line printer with a signal that 
allows the line printer initialization routine to be started. 


Line Printer Select: This open-drain line selects the printer when it is active low. 


Printer Port Interrupt - This signal is an active high, three-state output, generated by the 
positive transition of -ACK. It is enabled by bit 4 of the Write Control Register. 


Line Printer Error - This is an input line from the line printer. The line printer reports an 
error by holding this line low during the error condition. 


Line Printer Selected - This is an input line from the line printer that goes high when the 
line printer has been selected. 


Line Printer Busy - This is an input line from the line printer that goes high when the line 
printer is not ready to accept data. 


Line Printer Paper Empty - This is an input line from the line printer that goes high when 
the printer runs out of paper. 


Line Printer Acknowledge - This input goes low to indicate a successful data transfer has 
taken place. It generates a printer port interrupt during its positive transition. 


Power Supply - The power supply requirement is 5 V i5%. 


Ground (0 V) - All pins must be tied to ground for proper operation. 
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FUNCTIONAL 
DESCRIPTION: 
SERIAL CHANNEL REGISTERS 
Three types of internal registers are 
used in the serial channel of the 
VL16C451. They are used in the 
operation of the device, and are the 
control, status, and data registers. The 
control registers are the Bit Rate Select 
Register DLL (Divisor Latch LSB) and 
DLM (Divisor Latch MSB), Line Control 
Register, Interrupt Enable Register, and 
the Modem Control registers, while the 
status registers are the Line Status 
Registers and the Modem Status 
Register. The data registers are the 
Receiver BufferRegister and the 
Transmitter Holding Register. The 
Address, Read, and Write inputs are 
used in conjunction with the Divisor 
Latch Access Bit in the Line Control 
Register [LCR(7)] to select the register 
to be written or read (see Table 1). 
Individual bits within these registers are 
referred to by the register mnemonic 
and the bit number in parenthesis. An 
example, LCR(7) refers to Line Control 
Register Bit 7. 


The Transmitter Buffer Register and 
Receiver Buffer Register are data 
registers holding from five to eight bits 
of data. If less than eight data bits are 
transmitted, data is right justified to the 


LSB. Bit 0 of a data word is always the 
first serial data bit received and 
transmitted. The VL16C451 data 
registers are double-buffered so that 
read and write operations can be 
performed at the same time the UART 
is performing the parallel-to-serial and 
serial-to-parallel conversion. 


The format of the data character is 
controlled by the Line Control Register. 
The contents of the LCR may be read, 
eliminating the need for separate 
storage of the line characteristics in 
system memory. The contents of the 
LCR are described below: 


LCR (O) Word Length Select Bit O 
(WLSO) 
LCR (1) Word Length Select Bit 1 
(WLS1) 
LCR (2) Stop Bit Select (STB) 
LCR (3) Parity Enable (PEN) 
LCR (4) Even Parity Select (EPS) 
LCR (5) Stick Parity 
LCR (6) Set Break 
LCR (7) Divisor Latch Access Bit 
(DLAB) 


LCR (0) and LCR(1) word length select 
bit 1: The number of bits in each serial 
character is programmed as shown in 
the following chart: 


TABLE 1 . SERIAL CHANNEL INTERNAL REGISTERS 
M m|:|m@ 


0 
O 
O 
0 
RBR 


0 
0 
0 
0 
THR 


0 
O 
1 
IER 


0 
1 
0 
IIR 


0 
1 
1 
LCR 


1 
0 
0 
MCR 


1 
0 
1 
LSR 


X 
1 
1 
O 
MSR 


X 
1 
1 
1 
SCR 


1 
0 
0 
0 
DLL 


1 
O 
O 
1 
DLM 


XXXXQ 


Register 


Receiver Buffer Register (read only) 


Transmitter Holding Register (write only) 


Interrupt Enable Register 


Interrupt Identification Register (read only) 


Line Control Register 


Modem Control Register 


Line Status Register 


Modem Status Register 


Scratch Register 


Divisor Latch (LSB) 


Divisor Latch (MSB) 


LCR(1) 
LCR(0) 
Word Length 


5 Bits 
6 Bits 
7 Bits 
8 Bits 
--00 


LCR(2) Stop Bit Select: LCR(2) 
specifies the number of stop bits in each 
transmitted character. If LCR(2) is a 
logic 0, one stop bit is generated in the 
transmitted data. If LCR(2) is a logic 1 
when a 5-bit word length is selected, 1.5 
stop bits are generated. lf LCR(2) is a 
logic 1 when either a 6-, 7-, or 8-bit word 
length is selected, two stop bits are 
generated. The receiver checks for two 
stop bits if programmed. 


LCR(3) Parity Enable: When LCR(3) is 
high, a parity bit between the last data 
word bit and stop bit is generated and 
checked. 


LCR(4) Even Parity Select: When parity 
is enabled [LCR(3)=1], LCR(4)-0 selects 
odd parity, and LCR(4)-1 selects even 
parity. 


LCR(5) Stick Parity: When parity is 
enabled [LCR(3)-1], CLR(5)=1 causes 
the transmission and reception of a 
parity bit to be in the opposite state from 
that indicated by LCR(4). This allows 
the user to force parity to a known state 
and for the receiver to check the parity 
bit in a known state. 


LCR(6) Break Control: When LCR(6) is 
set to a logic "1', the serial output 
(SOUT) is forced to the spacing (logic 0) 
state. The break is disabled by setting 
LCR(6) to a logic "0". The Break Control 
bit acts only on SOUT and has no effect 
on the transmitter logic. Break Control 
enables the CPU to alert a terminal in a 
computer communications system. If 
the following sequence is used, no 
erroneous or extraneous characters will 
be transmitted because of the break. 


1. Load an all "0"s pad character in 
response to THRE. 


2. Set break in response to the next 
THRE. 


3. Wait for the transmitter to be idle 
X - "Don't Care” 
0 - Logic Low 
1 -= Logic High 
(TEMT-=1), and clear break when 
Note: The serial channel is accessed when -CSO is low. 
“°'t"‘:g'a"sm'ss'°" has I° b° 
res o 
. 
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FIGURE 1. UNE CONTROL REGISTER 
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LCR 
LCR 
LCR 
LCR 
LCR 
LCR 
LCR 
LCR 
7 
6 
5 
4 
8 
2 
1 
0 


LCR(7) Divisor Latch Access Bit 
(DLAB): LCR(7) must be set high (logic 
'1") to access the Divisor Latches DLL 
and DLM of the Baud Rate Generator 
during a read or write operation. 
LCR(7) must be input low to access the 
Receiver Buffer, the Transmitter 
Holding, or the Interrupt Enable 
Registers. 


The Line Status Register (LSR) is a 
single register that provides status 
indications. The LSR is usually the first 
register read by the CPU to determine 
the cause of an interrupt or to poll the 
status the serial channel of the 
VL16C451. 


Three error flags OE, FE, and PE 
provide the status of any error condi- 
tions detected in the receiver circuitry. 
During reception of the stop bits, the 
error flags are set high by an error 
condition. The error flags are not reset 
by the absence of an error condition in 
the next received character. The flags 
reflect the last character only if no 
overrun otxurred. The Overrun Error 


O 
O 


VL16C451 


= 
5 Data Bits 
Word 
= 
6 Data Bits 
Length 
= 
7 Data Bits 
Select 
= 
8 Data Bits 
_4_|.Q 
-.4-Q-¢ 


Stop 
0 = 1 Stop Blt 
Bit Select 
1 = 1.5 Stop Bits If 5 Data Bits Selected 
2 Stop Bits if 6, 7,8 Data Bits Selected 
Parity 
0 = Parity Disabled 
Enable 
1 = Parity Enabled 


Even 
0 = Odd Parity 
Parity 
1 = Even Parity 
Select 


Stick 
0 = Stick Parity Disabled 
Parity 
1 = Stick Parity Enabled 


Break 
0 = Break Disabled 
Control 
1 = Break Enabled 


Divisor 
0 = Access Receiver Buffer 
Latch 
1 = Access Divisor Latches 
Access 
Bit 


character in the Receiver Buffer 
Register has been overwritten by a 
character from the Receiver Shift 
Register before being read by the CPU. 
The character is thereby lost. Framing 
Error (FE) indicates that the last 
character received contained incorrect 
(low) stop bits. This is caused by the 
absense of the required stop bit or by a 
stop bit too short to be detected. Parity 
Error (PE) indicates that the last 
character received had a parity error 
based on the programmed and calcu- 
lated parity of the received character. 


The Break Interrupt (BI) status bit 
indicates that the last character 
received was a break character. A 
break character is an invalid data 
character. However, it is an entire 
character, including parity and stop bits. 


The Transmitter Holding Register 
Empty (THRE) bit indicates that theTHR 
register is empty and may receive 
another character. The Transmission 
Shift Register Empty (TEMT) bit 
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indicates that the Transmitter Shift 
Register is empty, and the serial 
channel has completed transmission of 
the last character to be sent. If the 
interrupt is enabled [IER(1)], an active 
THRE causes an interrupt (INTRPT). 


The Data Ready (DR) bit indicates that 
the RBR has been loaded with a 
received character (including Break) 
and that the CPU may access this data. 


Reading the LSR clears LSR(1)- 
LSR(4). (OE, PE, FE, and BI.) 


The contents of the Line Status 
Register shown in Table 2 are de- 
scribed below: 


LSR(O) Data Ready (DR): Data Ready 
is set high when an incoming character 
has been received and transferred into 
the Receiver Buffer Register. LSR(O) is 
reset low by a CPU read of the data in 
the Reciever Buffer Register. 


LSR(1) Overrun Error (OE): Overrun 
Error indicates that data in the Receiver 
Buffer Register was not read by the 
CPU before the next character was 
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TABLE 2. LINE STATUS REGISTER BITS 


LSR BITS 


LSR(O) Data Ready (DR) 


LSR (1) Overrun Error (OE) 


LSR(2) Parity Error (PE) 


LSR (3) Framing Error (FE) 


LSR (4) Break Interrupt (Bl) 


LSR (5) Transmitter Holding Register Empty (Tl-IRE) 
Empty 


LSR (6) Transmitter Empty (TEMT) 


LSR (7) Not Used 


Loglc 1 
Loglc 0 


Ready 
Not Ready 


Error 
No Error 


Error 
No Error 


No Error 


No Break 


Not Empty 


Not Empty 


Error 


Break 


Empty 


transferred into the Receiver Buffer 
Register, overwriting the previous 
character. The OE indicator is reset 
whenever the CPU reads the contents 
of the Line Status Register. 


LSR(2) Parity Error (PE): Parity Error 
indicates that the received data 
character does not have the correct 
even or odd parity, as selected by the 
Even Parity Select bit (LCR(4)). The 
PE bit is set high upon detection of a 
parity error, and is reset low when the 
CPU reads the contents of the LSR. 


LSR(3) Framing Error (FE): Framing 
Error indicates that the received 
character did not have a valid stop bit. 
LSR(3) is set high when the stop bit 
following the last data bit or parity bit is 
detected as a zero bit (spacing level). 
The FE indicator is reset low when the 
CPU reads the contents of the LSR. 


LSR(4) Break Interrupt (Bl): Break 
Interrupt is set high when the received 
data input is held in the spacing (logic 
0) state for longer than a full word 
transmission time (start bit + data bits + 
pairty + stop bits). The Bl indicator is 
reset when the CPU reads the contents 
of the Line Status Register. 


LSR(1) - LSR(4) are the error condi- 
tions that produce a Reciever Line 
Status interrupt (priority 1 interrupt in 
the Interrupt Identification Register 
(llR)) when any of the conditions are 
detected. This interrupt is enabled by 
setting lER(2)=1 in the Interrupt Enable 
Register. 


LSR(5) Transmitter Holding Register 
Empty (THRE): THRE indicates that 
the VL82C50A is ready to accept a new 
character for transmission. The THRE 


bit is set high when a character is 
transferred from the Transmitter 
Holding Register into the Transmitter 
Shift Register. LSR(5) is reset low by 
the loading of the Transmitter Holding 
Register by the CPU. LSR(5) is not 
reset by a CPU read of the LSR. 


When the THRE interrupt is enabled 
(lER(1)=1). THRE causes a priority 3 
interrupt in the IIR. If THRE is the 
interrupt source indicated in IIR, 
INTRPT is cleared by a read of the IIR. 


LSR(6) Transmitter Empty (TEMT): 
TEMT is set high when the Transmitter 
Holding Register (THR) and the 
Transmitter Shift Register (TSR) are 
both empty. LSR(6) is reset low when 
a character is loaded into the THR and 
remains low until the character is 
transferred out of SOUT. TEMT is not 
reset low by a CPU read of the LSR. 


LSR(7): This bit is always 0. 


The Modem Control Register (MCR) 
controls the interface with the modem 
or data set as described in Table 3. 


VL16C451 


MCR can be written and read. The 
-RTS and -DTR outputs are directly 
controlled by their control bits in this 
register. A high input asserts a low 
(true) at the output pins. MCR Bits 0, 1, 
3, and 4 are shown below: 


MCR(O): When MCR(O) is set high, the 
-DTR output is forced low. When 
MCR(O) is reset low, the -DTR output is 
forced high. The -DTR output of the 
serial channel may be input into an 
inverting line driver in order to obtain 
the proper polarity input at the modem 
or data set. 


MCR(1): When MCR(1) is set high, the 
RTS output is forced low. Whe MCR(1) 
is reset low, the -RTS output is forced 
high. The —RTS output of the serial 
channel may be input into an inverting 
line driver in order to obtain the proper 
polarity input at the modem or data set. 


MCR(3): When MCR(3) is set high, the 
INT output is enabled. 


MCR(4): MCR(4) provides a local 
loopback feature for diagnostic testing 
of the channel. When MCR(4) is set 
high, Serial Output (SOUT) is set to the 
marking (logic '1") state, and the 
receiver data input Serial Input (SIN) is 
disconnected. The output of the 
Transmitter Shift Register is looped 
back into the Receiver Shift Register 
input. The three modem control inputs 
(—CTS, -DSR, and -RI) are discon- 
nected. The modem control outputs 
(-DTR and —RTS) are internally con- 
nected to the four modem control 
inputs. The modem control output pins 
are forced to their inactive state (high). 


TABLE 3. MODEM CONTROL REGISTER BITS 
MCR BITS 
Loglc 1 
Loglc 0 


MCR (0) DataTerminal Ready (DTR) 
-DTR Output Low 
-DTR Output High 


MCR (1) Request to Send (RTS) 
—RTS Output Low 
-RTS OutputHigh 
MCR (2) o 


MCR (3) Interrupt (INT) Enable 
INT Enabled 
INT Disabled 


MCR (4) LOOP 
Loop Enabled 
Loop Disabled 
MCR (5) 0 
MCR (6) o 
MCS (7) 0 
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FIGURE 2. MODEM CONTROL REGISTER 


Modem Control Register (MCR) 


MCR MCR MCR MCR MCR MCR MCR MCR 
7 
6 
i 5 
4 
3 
2 
1 
0 


In the diagnostic mode, data transmit- 
ted is immediately received. This 
allows the processor to verify the 
transmit and receive data paths of the 
selected serial channel. Bits MCR(5) - 
MCR(7) are permanently set to logic 0. 


The MSR provides the CPU with status 
of the modem input lines from the 
modem or peripheral devices. The MSR 
allows the CPU to read the serial 
channel modem signal inputs by 
accessing the data bus interface of the 
VL16C451. In addition to the current 
status information, four bits of the MSR 
indicate whether the modem inputs have 
changed since the last reading of the 
MSR. The delta status bits are set high 
when a control input from the modem 
changes state, and reset low when the 
CPU reads the MSR. 


The modem input lines for the channel 
are —CTS, —DSR, —RI, and -RLSD. 
MSR(4) - MSR(7) are status indications 
of these lines. The status indications 
follow the status of the input lines. 
If the 
modem status interrupt in the Interrupt 
Enable Register is enabled [lER(3)], a 
change of state in a modem input 
signals will be reflected by the modem 
status bits in the IIR register, and an 
interrupt (INTRPT) is generated. The 
MSR is a priority 4 interrupt. The 
contents of the Modem Status Register 
are described in Table 4. Note that the 
state (high or low) of the status bits are 


Data 
0 
Terminal 
1 
Ready 


Request 
0 
To Send 
1 


NC 


INT 
0 


1 


LOOP 


-o 


$ 


5 


VL16C451 


-DTR Output High (Inactive) 
-DTR Output Low (Active) 


—RTS Output High (Inactive) 
—RTS Output Low (Active) 


Not Connected 


INT Disabled 
INT Enabled 


LOOP Disabled 
LOOP Enabled 


These Bits are Permanently Set to Logic '0". 


inverted versions of the actual input 
pins. 


MSR(0) Delta Clear to Send (DCTS): 
DCTS indicates that the —CTS input to 
the serial channel has changed state 
since the last time it was read by the 
CPU. 


MSR(1) Delta Data Set Ready (DDSR): 
DDSR indicates that the —DSR input to 
the serial channel has changed state 
since the last time it was read by the 
CPU. 


MSR(2) Trailing Edge of Ring Indicator 
(TERI): TERI indicates that the —RI 
input to the serial channel has changed 
state from high to low since the last 
time it was read by the CPU. Low to 
high transitions on —Rl0 do not activate 
TERI. 


MSR(3) Delta Data Carrier Detect 
(DRSLD): DRSLD indicates that the 


-RSLD input to the serial channel has 
changed state since the last time it was 
read by the CPU. 


MSR(4) Clear to Send (CTS): Clear to 
Send (CTS) is the status of the —CTS 
input from the modem indicating to the 
serial channel that the modem is ready 
to receive data from the serial channel's 
transmitter output (SOUT). If the serial 
channel is in loop mode [MSR(4)=1], 
MSR(4) is equivalent to —RTS in the 
MCR. 


MSR(5) Data Set Ready (DSR): Data 
Set Ready (DSR) is a status of the 
-DSR input from the modem to the 
serial channel which indicates that the 
modem is ready to provide received 
data to the serial channel receiver 
circuitry. If the channel is in the loop 
mode [MCR(4)=1], MSR(5) is equiva- 
lent to the DTR in the MCR. 


TABLE 4. MODEM STATUS REGISTER BITS 
MSR Bit 
Description 


MSR 
MSR 
MSR 
MSR 
MSR 
MSR 
MSR 
MSR 
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(1) 
DDSR 
Delta Data Set Ready 
(2) 
TERI 
Trailing Edge of Ring Indicator 
(O) 
DCTS 
Delta Clear to Send 
(3) 
DRLSD 
Delta Data Carrier Detect 
(4) 
-CTS 
Clear To Send 
(5) 
-DSR 
Data Set Ready 
(6) 
-RI 
Ring Indicator 
(7) 
-RLSD 
Receiver Line Signal Detect 
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MSR(6) Ring Indicator: Indicates the 
status fo the RI input (pin 39). If the 
channel is in the loop mode 
[MCR(4)=1], MSR(6) is not connected 
in the MCR. 


MSR(7) Receive Line Signal Detect : 
Receive Line Signal Detect indicates 
the status of the Receive Line Signal 
Detect (-RLSD) input . If the channel is 
in the loop mode [MCR(4)-1], MSR(4) is 
equivalent to OUT2 of the MCR. 


The modem status inputs (-RI, -RLSD, 
-DSR, and —CTS) reflect the modem 
input lines with any change of status. 
Reading the MSR register will clear the 
delta modem status indications but has 
no effect on the status bits. The status 
bits reflectthe state of the input pins 
regardless of the mask control signals. 
If a DCTS, DDSR, TERI, or DRLSD are 
true, and a state change occurs during 
a read operation (-IOR), the state 
change is not indicated in the MSR. lf 
DCTS, DDSR, TERI, or DRLSD are 
false, and a state change occurs during 
a read operation, the state change is 
indicated after the read operation. 


For LSR and MSR, the setting of status 
bits is inhibited during status register 
read -IOR operations. If a status 
condition is generated during a read 
-IOR operation, the status bit is not set 
until the trailing edge of the read 
-IOR. 


If a status bit is set during a read 
-IOR operation, and the same status 
condition occurs, that status bit will be 
cleared at the trailing edge of the read 
-IOR instead of being set again. 


The VL16C451 serial channel contains 
a programmable Baud Rate Generator 
(BRG) that divides the clock (DC to 
3.1 MHz) by any divisor from 1 to 2 164 
(see also BRG description). The output 
frequency of the Baud Generator is 16X 
the data rate [divisor # -= clock + (baud 
rate x 16)]. Two 8-bit divisor latch 
registers store the divisor in a 16-bit 
binary format. These Divisor Latch 
registers must be loaded during 
initialization. Upon loading either of the 
Divisor latches, a 16-bit baud counter is 
immediately loaded. This prevents long 
counts on initial load. 


The receiver circuitry in the serial 
channel ofthe VL16C451 is program- 
mable for 5, 6, 7, or 8 data bits per 


character. For words of less than 8 
bits, the data is right justified to the 
least significant bit LSB = Data Bit 0 
[RBR(0)]. Data Bit 0 of a data word 
[RBR(0)] is the first data bit received. 
The unused bits in a character less than 
8 bits are output low to the parallel 
output by the serial channel. 


Received data at the SIN input pin is 
shifted into the Receiver Shift Register 
by the 16X clock provided at the RCLK 
input. This clock is synchronized to the 
incxaming data based on the position of 
the start bit. When a complete charac- 
ter is shifted into the Receiver Shift 
Register, the assembled data bits are 
parallel loaded into the Receiver Buffer 
Register. The DR flag in the LSR 
register is set. 


Double buffering of the received data 
permits continuous reception of data 
without losing received data. While the 
Receiver Shift Register is shifting a new 
character into the serial channel, the 
Receiver Buffer Register is holding a 
previously received character for the 
CPU to read. Failure to read the data in 
the RBR before complete reception of 
the next character result in the low of 
the data in the Receiver Register. The 
OE flag in the LSR register indicates 
the overrun condition. 


RBR Bits 0 thru 7: 


THR Bits 0 thru 7 


THR(0) 
Data Bit 0 
THRU) 
THRQ) 
THRB) 
THRM) 
THR6) 
THR@) 
THRU) 


DmaBh1 
DmaBh2 
DmaBh3 
DmaBh4 
DmaBh5 
DmaBh6 
DmaBh7 


Scratchpad Register is an 8-btt Read/ 
Write register that has no effect on 
either channel in the VL16C451. It is 
intended to be used by the program- 
mer to hold data termporarily. 


SCR Bits O thru 7 
scam) 
scan) 
scam) 
scnp) 
scnu) 
scnw) 
scam) 
scan) 


DmaBhO 
DmaBh1 
DmaBh2 
DmaBh3 
DmaBh4 
DmaBh5 
DmaBh6 
DmaBh7 


RBRQ) 
RBRU) 
RBRQ) 
Reap) 
RBRM) 
RBR6) 
RBR@) 


DmaBh0 
DmaBh1 
DmaBh2 
DmaBH3 
DmaBh4 
DmaBh5 
DmaBh6 
RBR(7) 
Data en 7 


The Transmitter Holding Register (THR) 
holds parallel data from the data bus 
(DO-D7) until the Transmitter Shift 
Register is empty and ready to accept a 
new character for transmission. The 
transmitter and receiver word length 
and number of stop bits are the same. 
If the character is less than eight bits, 
unused bits at the microprocessor data 
bus are ignored by the transmitter. 


Data Bit 0 [I'HR(0)] is the first serial 
data bit transmitted. The THRE flag 
[LSR(5)] reflect the status of the THR. 
The TEMT flag [LSR(5)] indicates if 
both the THR and TSR are empty. 
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INTERRUPTS 
The Interrupt Identification Register 
(IIR) in the serial channel of the 
VL16C451 has interrupt capability for 
interfacing to current microprocessors. 
In order to minimize software overhead 
during data character transfers, the 
serial channel prioritizes interrupts into 
four levels. The four levels of interrupt 
conditions are as follows: 


1. Receiver Line Status (priority 1) 
2. Received Data Ready (priority 2) 
3. Transmitter Holding Register Empty 
(priority 3) 
4. Modem Status (priority 4) 


Information indicating that a prioritized 
interrupt is pending and the type of 
interrupt is stored in the Interrupt 
Identification Register (IIR). When 
addressed during chip select time, the 
IIR indicates the highest priority 
interrupt pending. No other interrupts 
are acknowledged until the interrupt is 
serviced by the CPU. The logic equiva- 
lent of the interrupt control circuit is 
shown in Figure 3. The contents of the 
IIR are indicated in Table 5 and are 
described below. 


IIR(0): IlR(0) can be used in either a 
hard-wired prioritized or polled environ- 
ment to indicate whether an interrupt is 
pending. When IlR(0) is low, an 
interrupt is pending, and IIR contents 


TABLE 5. INTERRUPT IDENTIFICATION REGISTER 
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INTERRUPT IDENTIFICATION 
INTERRUPT SET AND RESET FUNCTIONS 


B“ 2 
Prlorlty 
Interrupt 
Interrupt 
Interrupt 
Level 
Flag 
Source 
Reset Control 


X 
X 
1 


1 
1 
0 
First 


1 
0 
0 
Second 


O 
1 
0 
Third 


0 
. 
O 
0 
Fourth 


X = Not Defined. 


FIGURE 3. INTERRUPT CONTROL LOGIC 


on (LSR BIT o) 
ERBFI (IER BIT o 


THRE (LSR BIT s 
ETBEI (IER BIT 1 


OE (LSR BIT 1) 
PE (LSR BIT 2) 


FE (LSR BIT s) 
y 
st (LSR en 4) 
ELSI (IER BIT 1) 
ocrs (MSR en o 
oosn (MSR BIT 1 
D 
TERI (MSR BIT 2) 
coco (MSR BIT s 


EDSSI (IER BIT 3) 


Interrupt Enable (MCR BIT 3) 


None 


Receiver 
Line Status 


Received Data 
Available 


THRE 


Modem Status 
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None 


OE, PE 
LSR Read 
FE, or BI 


Received Data 
RBR Read 
Available 


THRE 
IIR Read if THRE is the 
Interrupt Source or THR Write 


-CTS, —DSR 
MSR Read 
-RI, -RSLD 


D 
INTERRUPT 
OUTPUT 


® VLSI TECHNOLOGY mc. 


TABLE 6. SERIAL CHANNEL ACCESSIBLE REGISTERS 


Register 
Register Blt Number 


VL16C451 


RBR 
Data 
(Read Only) 
Bit 7 
(MSB) 


THR 
Data 
(Write Only) 
Bit 7 


DLL 
Bit 7 


DLM 
Bit 15 


IER 
0 


IIR 
o 
(Read Only) 


LCR 
(DLAB) 
Divisor 
Latch 
Access 
Bit 


MCR 
0 


Data 
Bit 6 


Data 
Bit 6 


Bit 6 


Bit 14 


O 


0 


Set 
Break 


O 


Data 
Bit 5 


Data 
Bit 5 


Bit 5 


Bit 13 


0 


0 


Stick 
Parity 


0 


LSR 


MSR 


SCR 


0 
(TEMT) 
(THRE) 
Transmitter 
Transmitter 
Empty 
Holding 
Register 
Empty 


(DCD) 
(RI) 
(DSR) 
Data 
Ring 
Data 
Carrier 
Indicator 
Ready 
Detect 
Set 


Bit 7 
Bit 6 
Bit 5 


‘LSB Data Bit 0 is the first bit transmitted or received. 


Data 
Bit 4 


Data 
Bit 4 


Bit 4 


Bit 12 


0 


0 


(EPS) 
Even 
Parity 
Select 


Loop 


(Bl) 
Break 


Data 
Bit 3 


Data 
Bit 3 


Bit 3 


Bit 11 


(EDSSI) 
Enable 
Modem 
Status 
Interrupt 


0 


(PEN) 
Parity 
Enable 


Out 2 


(FE) 
Framing 
Interrupt 
Error 


Data 
Bit 2 


Data 
Bit 2 


Bit 2 


Bit 10 


(ELSI) 
Enable 
Receiver 
Line 
Status 
Interrupt 


Interrupt 
ID 
Bit (1) 


(STB) 
Number 
of Stop 
Bits 


Out 1 


(PE) 
Parity 
Error 


(CTS) 
(DRSLD) 
(TERI) 
Clear 
Delta 
Trailing 
to 
Receive 
Edge 
Send 
Line Signal 
Ring 
Detect 
Indicator 


Bit 4 
Bit 3 
Bit 2 
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Data 
Bit 1 


Data 
Bit 1 


Bit 1 


Bit 9 


(ETBEI) 
Enable 
Transmitter 
Holding 
Register 
Empty 
Interrupt 


Interrupt 
ID 
Bit (O) 


(w|_ss1) 
Word 
Length 
Select 
Bit 1 


(RTS) 
Request 
To 
Send 


(0E) 
Overrun 
Error 


(DDSR) 
Delta 
Data 
Set 
Ready 


Bit 1 


Data 
Bit 0 
(LSB)' 


Data 
Bit 0 


BitO 


Bit8 


(ERBFI) 
Enable 
Received 
Data 
Available 
Interrupt 


"0" 1 F 
Interrupt 
Pending 


(WLSBO) 
Word 
Length 
Select 
Bit 0 


(DTR) 
Data 
Terminal 
Ready 


(DR) 
Data 
Ready 


(DCTS) 
Delta 
Clear 
to 
Send 


BitO 


may be used as a pointer to the appro- 
priate interrupt service routine. When 
llR(0) is high, no interrupt is pending. 


llR(1) and llR(2) are used to identify the 
highest priority interrupt pending as 
indicated in Table 2. 


llR(3) - llR(7): These five bits of the IIR 
are logic 0. 


The Interrupt Enable Register (IER) is a 
Write register used to independently 
enable the four serial channel interrupts 
which activate the interrupt (INTRPT) 
output. All interrupts are disabled by 
resetting lER(0) - lER(3) of the Interrupt 
Enable Register. Interrupts are enabled 
by setting the appropriate bits of the IER 
high. Disabling the interrupt system 
inhibits the Interrupt Identification 
Register and the active (high) INTRPT 
output. All other system functions 
operate in their normal manner, includ- 
ing the setting of the Line Status and 
Modem Status Registers. The contents 
of the Interrupt Enable Register is de- 
scribed in Table 3 and below: 


lER(0): When programmed high 
[lER(0)=Logic 1], IER(0) enables 
Received Data Available interrupt. 


IER(1): When programmed high 
[lER(1)=Logic1], IER(1) enables the 
Transmitter Holding Register Empty 
interrupt. 


lER(2): When programmed high 
[lER(2)=Logic 1], lER(2) enables the 
Receiver Line Status interrupt. 


lER(3): When programmed high 
[lER(3)=-Logic 1], lER(3) enables the 
Modem Status Interrupt. 


lER(4) - lER(7): These four bits of the 
IER are logic O. 


TRANSMITTER 
The serial transmitter section consists of 
a Transmitter Holding Register (TI-I R), 
Transmitter Shift Register (TSR), and 
associated control logic. The Transmit- 
ter Holding Register Empty (THRE) and 
Transmitter Shift Register Empty 
(TEMT) are two bits in the Line Status 
Register which indicate the status of 
THR and TSR. To transmit a 5- to 8-bit 
word, the word is written through D0-D7 
to the THR. The microprocessor should 
perform a write operation only if THRE is 
high. The THRE is set high when the 
word is automatically transferred from 
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the THR to the TSR during the transmis- 
sion of the start bit. 


When the transmitter is idle, THRE and 
TEMT are high. The first word written 
causes THRE to be reset to 0. After the 
transfer, THRE returns high. TEMT 
remains low for at least the duration of 
the transmission of the data word. If a 
second character is transmitted to the 
THR, the THRE is reset low. Since the 
data word cannot be transferred from the 
THR to the TSR until the TSR is empty, 
THRE remains low until the TSR has 
completed sending the word. When the 
last word has been transmitted out of the 
TSR, TEMT is set high. THRE is set 
high one THR to TSR transfer time later. 


RECEIVER 
Serial asynchronous data is input into 
the SIN pin. The idle state of the line 
providing the input into SIN is high. A 
start bit detect circuit continually 
searches for a high to low transition from 
the idle state. When the transition is 
detected, a counter is reset, and counts 
the 16X clock to 7 1/2, which is the 
center of the start bit. The start bit is 
valid if the SIN is still low at the mid-bit 
sample of the start bit. Verifying the 
start bit prevents the receiver from 
assembling a false data character due to 
a low going noise spike on the SIN input. 


The Line Control Register determines 
the number of data bits in a character 
(LCR(O), LCR(1)), number of stop bits 
LCR(2), if parity is used LCR(3), and the 
polarity of parity LCR(4). Status for the 
receiver is provided in the Line Status 
Register to the Receiver Buffer Register, 
the Data Received indication in LSR(O) 
is set high. The CPU reads the Receiver 
Buffer Registerthrough D0-D7. This 
read resets LSR(O). If D0-D7 are not 
read prior to a new character transfer 
from the RSR to the RBR, the overrun 
error status indication is set in LSR(1). 
The parity check tests for even or odd 
parity on the parity bit, which precedes 
the first stop bit. If there is a parity error, 
the parity error is set in LSR(2). There is 
circuitry which tests whether the stop bit 
is high. If it is not, a framing error 
indication is generated in LSR(3). 


The center of the start bit is defined as 
clock count 7 1/2. If the data into SIN is 
symmetrical square wave, the center of 
the data cells will occur within 
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:1: 3.125% of the actual center, providing 
an error margin of 46.875%. The start 
bit can begin as much as one 16X clock 
cycle prior to being detected. 


BAUD RATE GENERATOR (BRG) 
The BRG generates the clocking for the 
UART function, providing standard 
ANSI/CCITT bit rates. The oscillator 
driving the BRG is provided by an 
external clock into CLK. 


The data rate is determined by the 
Divisor Latch registers DLL and DLM 
and the external frequency. The bit rate 
is selected by programming the two 
divisor latches, Divisor Latch Most 
Significant Byte and Divisor Latch Least 
Significant Byte. Setting DLL=1 and 
DLM=0 selects the divisor to divide by 1 
(divide by 1 gives maximum baud rate 
for a given input frequency at the CLK 
input). 


The BRG can use any of three different 
popular frequencies to provide standard 
baud rates. These frequencies are 
1.8432 MHz, 2.4576 MHz, and 3.072 
MHz. With these frequencies, standard 
bit rates from 50 to 38.5 kbps are 
available. Tables 7, 8, and 9 illustrate 
the divisors needed to obtain standard 
rates using these three crystal frequen- 
cies. 


RESET 
After power up, the VL16C451 -RESET 
input should be held low for 500 ns to 
reset the VL16C451 circuits to an idle 
mode until initialization. A low on 
-RESETcauses the following: 


1. Initializes the transmitter and 
receiver internal clock counters. 


2. Clears the Line Status Register 
(LSR), except for Transmitter Shift 
Register Empty (TEMT) and 
Transmit Holding Register Empty 
(THRE), which are set. The Modem 
Control Register (MCR) is also 
cleared. All of the discrete lines, 
memory elements and miscellane 
ous logic associated with these 
register bits are also cleared or 
turned off. The Line Control 
Register (LCR), Divisor Latches, 
Receiver Buffer Register, Transmit 
ter Buffer Register are not effected. 


Following removal of the reset condition 
(Reset high), the VL16C451 remains in 
the idle mode until programmed. 


A hardware reset of the VL16C451 sets 
the THRE and TEMT status bit in the 
LSR. When interrupts are subsequently 
enabled, an interrupt occurs due to 
THRE. 


A summary of the effect of a reset on 
the VL16C451 is given in Table 10. 


PROGRAMMING 
Each serial channel of the VL16C451 is 
programmed by the control registers 
LCR, IER, DLL and DLM, and MCR. 
These control words define the charac- 
ter length, number of stop bits, parity, 
baud rate, and modem interface. 
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While the control register can be written 
in any order, the IER should be written 
to last because it controls the interrupt 
enables. Once the serial channel is 
programmed and operational, these 
registers can be updated any time the 
VL16C451 serial channel is not 
transmitting or receiving data. 


The control signals required to access 
each serial channel's internal registers 
are shown below. 


SOFTWARE RESET 
A software reset of the serial channel is 
a useful method for returning to a 


TABLE 7. BAUD RATES (1.8432 MHZ CLOCK) 
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completely known state without a 
system reset. Such a reset consists of 
writing to the LCR, Divisor Latches, and 
MCR registers. The LSR and RBR 
registers should be read prior to 
enabling interrupts in order to clear out 
any residual data or status bits which 
may be invalid for subsequent 
operation. 


CLOCK INPUT OPERATION 
The maximum input frequency of the 
external clock of the VL16C451 is 
3.1 MHz. 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 
56000 


2304 


1 536 


1 O47 
857 
768 
384 


1 92 
96 
64 
58 
48 
32 
24 


1 6 


1 2 
6 
3 
2 
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0.026 
0.058 


0.69 


2.86 


w VLSI TECHNOLOGY, mc 


TABLE 8. BAUD RATES (2.4576 MHZ CLOCK) 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


50 
75 
110 
134£5 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 


3072 
2048 
1396 


1 142 
1024 
512 
256 
128 
85 
77 
64 
43 
32 
21 
16 
8 
4 


TABLE 9. BAUD RATES (3.072 MHZ CLOCK) 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 


3840 
2560 
1745 
1428 
1280 
640 
320 
160 
107 
96 
80 
53 
40 
27 
20 
10 
5 
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0.026 
0.0007 


0.392 
0.260 


0.775 


1.587 


0.026 
0.034 


0.312 


0.628 


1.23 
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TABLE 10. RESET 


Register/Slgnal 


Interrupt Enable Register 
. 
Interrupt Identification 
Register 
Line Control Register 
MODEM Control Register 
Line Status Register 
MODEM Status Register 


SOUT 
lntrpt (RCVR Errs) 
lntrpt (RCVR Data Ready) 
lntrpt (THRE) 
lntrpt (Modem Status Changes) 
"—Out2 
—RTS 
-DTR 
—Out1 


DEVICE APPLICATION 


Reset 
Reset 


Reset 
Reset 
Reset 
Reset 


Reset 
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Reset Control 


Read LSR/Reset 
Read RBR/Reset 
Read IIR/Write THR/Reset 
Read MSR/Reset 
Reset 
Reset 
Reset 
Reset 


VL16C451 


All Bits Low (0-3 forced and 4-7 permanent) 
Bit O is High, Bits 1 and 2 Low 
Bits 3--7 are Permanently Low 
AII Bits Low 
A I Bits Low 


B'ts 0-3 Low 


H'gh 
Low 
Low 
Low 
Low 
High 
High 
High 
High 


Bits 4-7 Input Signal 


SERIAL 


Reset 
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All Bits Low, Except Bits 5 and 6 are High 


DATA 
cmtnuet 0 
9"°"" 
— 
" 
" 
BUS 
— 
_@ 
D 


ADDR 
BUS 


UART AND 
QT|_ 
PRINTER 
Bus 
PORT 
OPTION 
JUMPERS 
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R/C NET 
I 
PORT 


BUFFERS 
CONN 


25-PIN 
“DH 


CONN 
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FUNCTIONAL 
DESCRIPTION 
PARALLEL PORT REGISTERS 
The Read Status Register allows the 
They are Interrupt Enable (IRO ENB), 
The VL16C451's parallel port interfaces 
microprocessor to read the status of the 
Select In (SLIN), Initialize the Printer 
the device to a Centronics-style printer. 
printer in the five most significant bits. 
(—INlT), Autofeed the Paper (AUTOFD), 
When Chip Select 2 (-CS2) is low, the 
The status bits are Printer Busy 
Strobe (STROBE), which informs the 
parallel port is selected. Table 11 
(-BUSY), Acknowledge (-ACK) which 
printer of the presence of a valid byte 
shows the registers associated with this 
is a handshake function, Paper Empty 
on the parallel bus. The Write Data 
parallel port. The read or write function 
(PE), Printer Selected (SLCT), and 
Register allows the microprocessor to 
of the register is controlled by the state 
Error 
write a byte to the parallel bus. 
of the read (—IOR) and write 
(-ERROR). The Read Control Register 
- 
_ 
(-IOW) pin as shown. The Read Data 
allows the state of the control lines to 
lT:£§Lat|:1eeI ::?a'|?eT°p::|i?rt‘ZI|:'3;°eI$);t 
Register allows the microprocessor to 
be read. The Write Control Register 
read the information on the parallel bus. 
sets the state of the control lines. 
gzggéerd In the IBM Sena‘/Parallel 


TABLE 11. PARALLEL PORT REGISTERS 


Register 
Register Bits 
' 


Bn7 
n 
BRO 
=12 
Q 


—L 


Read Data 
PD7 
PD4 
PDQ 


Read SIQIUS 
—BUSY 
-ACK 
SLCT 
—ERRQFI 


Read Control 
IRQ ENB 
SLIN 
—-INIT 
AUTQFD 
STRQBE 


Write Data 
PD7 
P00 
Write Control 
IRQ ENB 
sun 
-INIT 
AUTOFD srnoee 


TABLE 12. PARALLEL PORT REGISTER SELECT 
Control Pins 
Register Selected 


------ 
-oooo 
6 


1] 
to 
Read Data 
Read Status 
Read Control 
Invalid 
Write Data 
Invalid 
Write Control 
Invalid 
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AC CHARACTERISTICS TA= o<>c to +1o°c, vcc= 5 v 15% (Notes 


Parameter 
Symbol 


tDIW 


RC 


tDDD 


IHZ 


tDOW 


WC 


tDS 


tDH 


tRA 


IRCS 


tAR 


tCSR 


tWA 


IWCS 


tAW 


tCSW 


tRW 


tXH 


tXL 


Notes 


1. All timing specifications apply to pins on both serial channels (e.g. RI refers to both RIO and RI1). 


... 
"''5 


ID 


Q 


-B 


"InOO 
§I 


— 
Strobe Width 


Read Cyle 


Delay from —IOR to Data 


—lOR to Floating Data Delay 


— OW Strobe Width 


Write Cycle 


Data Setup Time 


Data Hold Time 


Address Hold Time from -IOR 


Chip Select Hold Time from -IOR 


-IOR Delay from Address 


-IOR Delay from Chip Select 


Address Hold Time from—IOW 


Chip Select Hold Time from -IOW 


-IOW Delay from Address 


—lOW Delay from Select 


Reset Pulse Width 


Duration of Clock High Pulse 


125 


-It 
AOO 
Duration of Clock Low Pulse 


2. The internal address strobe is always active. 
3. RCLK = tXH and tXL. 
4. Charge and discharge time is determined by VOL, VOH and the external loading. 
5. All timings are referenced to valid 0 and valid 1. 
(see AC TEST POINTS). 
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Conditions 


100 pF Load 


100 pF Load, Note 4 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


External Clock 


External Clock 
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AC CHARACTERISTICS (Cont.) TA= 0-c to +1000, vcc= s v :t5% (Notes 1, s) 


VL16C451 


5 


> 
7? 


Transmitter 


‘Hm 
Delay from Rising Edge of -IOW 
(WR THR) To Reset Interrupt 


Symbol 
Parameter 


-H 
CLK 
Cycles 


CLK 


tSl 
Delay from Initial Write to Interrupt 
24 
CYCIBS 


tSTl 
Delay from Stop to Interrupt (THRE) 
CI-K 
Cycles 


to Reset Interrupt (THRE) 


Receiver 


ISINT 
Delayfrom Stopto Set Interrupt 
Cygi 
iii" 
°i'i"'°'""°“ 
-- 
RD RBR/RDLSR to Reset lnterrut 


"Mme 
II 
es 
Si---i~m- 
mm 
tAD 
Acknowledge Delay (Busy Start to Acknowledge) 
1/“<0 
C 
ii 
tAK 
It 


*BSY 
ll 
BSD 
ii 


tlRS 
Delay from Initial INTR Reset to Transmit Start 


Modem Control 


Delay from -IOW 
‘M99 
(WR MCR) to Output 


tSlM 
Delay to Set Interrupt from MODEM Input 


tR|M 
Delay to Reset Interrupt from 
-IOR (RS MSR) 


Parallel Port 


tDT 


nowledge Delay (Busy End to Acknowledge) 


Acknowledge Duration Time 


Busy Duration Time 


Busy Delay Time 


Notes: 
_ 


1. All timing specifications apply to pins on both serial channels (e.g. RI refers to both RIO and RI1). 
2. The internal address strobe is always active. 
3. RCLK = tXH and tXL. 
4. Charge and discharge time is determined by VOL, VOH and the external loading. 
5. All timings are referenced to valid 0 and valid 1 (see AC TEST POINTS). 
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Conditions 


100 pF Load 


Note 3 


Note 3 


Note 3 


100 pF Load 


100 pF Load 


100 pF Load 


100 pF Load 


Note 3 


100 pF Load 


Defined by Printer 


Defined by Printer 


Defined by Printer 


Defined by Printer 


Def'ned by Printer 
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WRITE CYCLE TIMING 


A2 A1 A0 
VALID 


tWA 


_Q$ 
VALID 


tWCS 


tCSW —-Zb 


tAW 
WC 
4- tDOW 


-IOW 
ACTIVE 
_ 
ACTIVE 


-IOR 
§FACTlVE 


tos I 
4-toH>| 


DATA 
co-07 ——-1——-—--————-i 


READ CYCLE TIMING 


A2 A1 Ao 
' 
VALID 


tRA 


<g> 


_Cs 
VALID 


4- tRCS -> 


ICSR ———ZP 


tAR 
RC 
4- IDIW 


"'°R 
ACTIVE 
ACTIVE 


on 
i 
‘ 
-low 
3%CTIVE 


tDDD 4-—> 
-5 
|‘— 
IHZ 


DATA 
VALID 
D0-D7 
DATA 
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RECEIVER TIMING 


SIN 
(RECEIVER 
STOP 
.NpUT 
START 
DATA BITS 


DATA) 


SAMPLE 
CLK 
I 
I 
I 


ISINT 
4i 
INTERRUPT 
(DATA READY QR 
RCVR ERR) 


tRlNT 


-‘QR 
ACTIVE 


TRANSMITTER TIMING 
START 
START 
SERIAL 
DATA (5-s) 
. STOP (F2) 
OUT (souT) 
PARITY 
"R5 
—> 
4-— tSTl 
INTERRUPT 
(THRE) 
< tnn1 
-IOW 
(wn THR) 
4- tSi -> 
_> HR ‘_ 
-ion 
(no IIR) 


MODEM TIMING 


-IOW 
iwn MCR) 


tMDO 
tMoo —> 
-RTS,—DTR 


-CTS,-DSA,-RLSD 


-INTERRUPT 
! 


-ion 
(no MSR) 


-RI 
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PARALLEL PORTTIMING 


DATA 


srnoee 


-ACK 


—> 
tSB 
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IDT 
tDT 


‘- 


4i—— tAD -ii 4-—IAK—> 


BUSY 
tAKD 4- 


0 


IBSD -5 
IBSY -5 


AC TESTING INPUT/OUTPUT WAVEFORMS 


EXTERNAL CLOCK INPUT 
AC TEST POINTS 


4—> 
tXH 


CLK 


TEST CIRCUIT 



4-tXL-§ 


2.0 V 
2.0 V 


0.8 V 
0.8 V 


2.54 V 


F Output Under Test 


680 Q 


O 


82 pF‘ 


Includes Scope and Jig 
I 
Capacitance 
—_7_- 
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ABSOLUTE MAXIMUM RATINGS 


Ambient Operating 
Stresses above those listed may cause 
those indicated in this data sheet is not 
Temperature 
-10°C to +70°C 
permanent damage to the device. 
implied. Exposure to absolute maximum 
Storage Temperature _65oC to + 15000 
These_are stress ratings only, functional 
rating conditions for extended periods 
Supply Voltage to 
operation of this device at these or any 
may affect device reliability. 
th 
d't' 
b 
Ground Potential -0.5 v to vcc + 0.3 v 
° 6' con "ms a we 


Applied Output 
Voltage 
-0.5 V to VCC + 0.3 V 


Applied Input 
_ 
Voltage 
-0.5 V to + 7.0V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = 0 to +1o<>c, vcc = s v 2 5% 


S mbol 
Parameter 
Conditions 


VILX 
Clock Inut Low Voltae 


VIHX 
Clock Input High Voltage 
VCC 


VIL 
Input Low Voltage 


VIH 
Input High Voltage 
VCC 
V 


IOL = 4.0 mA on DBO - DB7 
IOL =12 mA on PDO - PD7 
VQL 
Qvtiwt Lew Voltage 
0-4 
V 
IOL = 1o mA on -NIT, -AFD, -srs, 
and -SLIN (see Note 1) 


e 
IOL = 2.0 mA on all other outputs 


IOH = -0.4 mA on DBO - DB7 
IOH =1 -2.0 mA On PDO - PD7 
von 
Output High Voltage 
2.4 
v 
IOH = -0.2 me on -INIT. -AFD. -STB. 
and -SLIN 
IOH = -0.2 mA on all other outputs 


VCC = 5.25 V, No loads on SINO; 
ICC 
Power Supply Current 
-D330; -RI-590; -CTSQ 
-RIO =- 2.0 V. Other inputs = 0.8 V. Baud 
rate generator = 4 MHz. Baud rate = 56K 


VCC = 5.25 V, GND = O V. 
Input Leakage 
1:10 
All other pins floating. 


ICL 
Clock Leakage 
:I: 
VIN = 0 V, 5.25 V 


VCC = 5.25 V, GND = 0 V. 
VOUT = O V, 5.25 V 
IOZ 
3-State Leakage 
:t20 
uA 
1) Chip deselected 


2) Chip and write mode selected 


VIL(RES) 
Reset Schmitt VIL 
V 


VlH(RES) 


IIL 


HI 
Reset Schmitt VIH 


Note 1. -INIT, -AFD, -STB, and -SLIN are open collector output pins that each have an internal pull-up resistor (2.5 kn - 3.5 k§2) 
to VCC. This will generate a maximum of 2.0 mA of internal IOL. In addition to this internal current, each pin will sink at least 
10 mA, while maintaining the VOL specification of 0.4 V Max. 
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FEATURES 
DESCRIPTION 
- IBM PC/AT-compatible 
The VL16C452 is an enhanced dual- 


- Dual-channel version of VL16C450 
channel version OI the popular 
VL16C450 asynchronous communi- 
° CBDIIQIIIX Printer interface 
cations element (ACE). The device 
, mdependent eenncn O‘ transmit, 
sen/es two serial input/output interfaces 
receive, line status and data set 
simultaneously in microcomputer- or 
interrupts en each channel 
microprocessor-based systems. Each 


_ 
. 
_ 
channel performs serial-to-parallel 
' Individual m°d°m ¢°"Ii°| $|9"aI$ 10' 
conversion on data characters received 
each °ha""°| 
from peripheral devices or modems, and 
. pregrernmeme eene| inteneee 
parallel-to-serial conversion on data 
enereetenence fer eeen enennek 
characters transmitted by the CPU. The 
._ 5..5-,7- or 3-1,“ Cnereetene 
complete status of each channel of the 
_ Even.’ odd- er nenenty bit 
dual ACE can be read at any time during 
generation and detection 
functional operation by the CPU. The 
_1' 1 1/2 er 2 Step en generenen 
information obtained includes the type 
and condition of the transfer operations 
- Three-state 'l'I'L drive for the data and 
being performed, and error conditions. 
control bus on each channel 


VL1 6C452 
DUALASYNCHRONOUS 
COMMUNICATIONS ELEMENT 


In addition to its dual communications 
interface capabilities, the VL16C452 
provides the user with a fully bidirec- 
tional parallel data port that fully 
supports the parallel Centronics type 
printer. This port allows information 
received from either serial communi- 
cation port to be printed from the dual 
ACE. The parallel port, together with the 
two serial ports, provide IBM PC/AT- 
compatible computers with a single 
device to serve the three system ports. 


A programmable baud rate generator is 
included that can divide the timing 
reference clock input by a divisor 
between 1 and (215 -1). 


The VL16C452 is housed in a 
68-terminal plastic leaded chip carrier. 


PIN DIAGRAM 
BLOCK DIAGRAM 


VL16C452 


—RSLD1—Rl1 
CLK 
GND 
-ACK 
BUSY 
VCC 
SINI 
—DSRO 


SOUTI 


-DTRI 


—RTS1 


—CTS1 


DBO 


DB1 


D82 


DB3 


DB4 


DB5 


DB6 


D87 


GND 


VCC 


-RTSO 


—DTF-IO 


SOUTO 


GND 
-D 
QZU 


10 


12 


13 


14 


15 


16 


17 


18 


19 


20 


22 


23 


24 


25 


26 


21 2a 29 so at 
I I I I I 
GND -RSLD -os 
-ctso 
-RIO 


-I -I ~I -I o\.$ a-T u-3"I .-.g 


8Im SIR SI 


SLCT 
-ERR 
GND 
IIIII 
ass-tsaezet 
so I INTI 


-CTSO 


-RLSDO 
-RIO 
SINO 
-CSO 


53 I -SLIN 


57 I -INIT 
56-AF0 


55 I -ste 
‘CTS’ 
—DSRI 
54 I GND 
-ntsot 
53PDO 
TOP VIEW 
52 I 
p01 


51 I PD2 


50 I PD3 


49 I PD4 


48 I PD5 


47 I PD6 


46 I PD7 
45lNT0 
44800 


53e8I 
felt: 
ls: 
gle 
L(D2 
I“ 
e§IS 
ee'f <§"° 
8 
I8 


Is 
gla 


A1 
G 
GND 


ORDER INFORMATION 
Part 
Maximum 


-Rlt 
SINI 
-cs1 


A0 - A2 
-IOW 
-IOR 
-RESET 
CLK 


—ERR 
SLOT 
BUSY 
PE 
-ACK 
-LPTOE 
-CS2 


-RTSO 
-DTRO 
SOUTO 
INT0 


UART 
#1 


8 


-RTSI 
-DTRI 
SOUTI 
INTI 


UART 
#2 


SELECT 
AND 
CONTROL 


' 
LOGIC 
BDO 


8 
PDO - PD7 
-INIT 
-AFD 
-sre 
-SLIN 
lNT2 


PARALLEL 
PORT 


Number 
Clock Frequency 
Package 


VL16C452-QC 
3.1 MHz 
Plastic Leaded Chip Carrier (PLCC) 


Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL DESCRIPTIONS 
Slgnal 
Name 


-IOR 


-IOW 


DBO-DB7 


A0, A1, A2 


CLK 


SOUTO, 
SOUT1 


-CTSO, -CTS1 


DSRO, DSR1 


DTRO, DTR1 


-RTSO, —RTS1 


—Rl0, —RI1 


-LPTOE 


VCC 


GND 


Pln 
Number 


37 


36 


14-21 


35, 34, 33 


4 


26,10 


28,13 


31,5 


25,11 


24.12 


30, 6 


1 


23, 40, 64 


2, 7, 9, 22, 27, 
42, 43, 54, 61 


VL1 6C452 


Slgnal 
Descrlptlon 


lnput/Output Read Strobe - This is an active low input which causes the selected channel 
to output data to the data bus (DBO-DB7). The data output depends upon the register 
selected by the address inputs A0, A1 , A2. Chip Select O (-CSO) selects UART #1, Chip 
Select 1 (-CS1) selects UART #2, and Chip Select 2 (-CS2) selects the line printer port. 


Input/Output Write Strobe - This is an active low input which causes data from the data 
bus (DBO-DB7) to be input to either UART or to theparallel port. The data input depends 
upon the register selected by the address inputs A0, A1, A2. The chip select inputs 
(-CSO, —CS1, and —CS2) enable UART#1, UART #2, and the parallel port (respectively). 


Data Bits DBO-DB7 - The Data Bus provides eight, three-state l/O lines for the transfer of 
data, control and status information between the VL16C452 and the CPU. These lines are 
normally in a high-impedance state except during read operations. DO is the least 
significant bit (LSB) and is the first serial data bit to be received or transmitted. 


Address Lines A0-A2 - The address lines select the internal registers during CPU bus 
operations. See Table 1 for the decode of the serial channels, Table 11 for the decode of 
the parallel line printer port.. 


Clock Input: The external clock input to the baud rate divisor of each UART. 


Serial Data Outputs - These lines are the serial data outputs from the UARTs' transmitter 
circuitry. A mark (1) is a logic "one" (high) and space (0) is a logic "zero" (low). Each 
SOUT is held in the mark condition when the transmitter is disabled, Reset is true, the 
Transmiter Register is empty, or when in the Loop Mode. 


Clear to Send Inputs - The logical state of each —CTS pin is reflected in the CTS bit of the 
(MSR) Modem Status Register [CTS is bit 4 of the MSR, written MSR (4)1 of each UART. 
A change of state in either —CTS pin since the previous reading of the associated MSR 
causes the setting of DCTS [MSR(0)] of each Modem Status Register. When a —CTS pin 
is low, the modem is indicating that data on the associated SOUT can be transmitted. 


Data Set Ready Inputs - The logical state of the DSR pins is reflected in MSR(5) of its 
associated Modem Status Register. DDSR [MSR(1)] indicates whether the associated 
DSR pin has changed state since the previous reading of the MSR. When a DSR pin is 
low, its modem is indicating that it is ready to exchange data with the associated UART. 


Data Terminal Ready Lines - Each DTR pin can be set (low) by writing a logic 1 to 
MCR(O), Modem Control Register bit O of its associated UART. This signal is cleared 
(high) by writing a logic O to the DTR bit [MCR(O)] or whenever a reset occurs. When 
active (low), the DTR pin indicates to the DCE that its UART is ready to receive data. 


Request to Send Outputs - The —RTS signal is an output on each UART used to enable 
the modem. An —RTS pin is set low by writing a logic 1 to MCR(1) bit 1 of its UART‘s 
Modem Control Register. Both -RTS pins are reset high by Reset. A low on the —RTS 
pin indicates to the DCE that its UART has data ready to transmit. In half duplex 
operations, -RTS is used to control the direction of the line. 


Ring Indicator Inputs - When low, -Rl indicates that a telephone ringing signal has been 
received by the modem or data set. The -Rl signal is a modem control input whose 
condition is tested by reading MSR(6) (RI) of each UART. The Modem Status Register 
output TERI [MSR(2)] indicates whether the Rl input has changed from high to low since 
the previous reading of the MSR. If the interrupt is enabled [lER(3)=1] and Rl changes 
from a high to low, an interrupt is generated. 


Parallel Data Output Enable - When low, this signal enables the Write Data Register to 
the PDO - PD7 lines. A high puts the PDO - PD7 lines in the high-impedence state allowing 
them to be used as inputs. -LPTOE is usually tied low for line printer operation. 


Power Supply - The power supply requirement is 5 V i5%. 


Ground (O V) - All pins must be tied to ground for proper operation. 


82 


® VLSI TECHNOLOGY, INC. 
VL1 6C452 


SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrl tlon 


-RLSDO, 
-RLSD1 


-RESET 


INTO, INT1 


SINO, SIN1 


-CSO, -CS1 
—CS2 


BDO 


PDO-PD7 


-STB 


-AFD 


-INIT 


-S LIN 


INT2 


-ERROR 


SLCT 


BUSY 


PE 


-ACK 


29, 8 


39 


45, 60 


41, 62 


32, 3, 38 


44 


53-46 


55 


56 


57 


58 


59 


63 


65 


66 


67 


68 


P 


Receive Line Signal Detect - When low, the -RLSD output indicates that the data carrier 
has been detected by the modem or data set. -RLSD is a modem input whose condition 
can be tested by the CPU by reading MSR(7) (RLSD) of the Modem Status Registers. 
MSR(3) (DRLSD) of the Modem Status Register indicates whether the -RLSD input has 
changed since the previous reading of the MSR. -RLSD has no effect on the receiver. If 
the -RLSD changes state with the modem status interrupt enabled, an interrupt occurs. 


Reset - When low, the reset input forces the VL16C452 into an idle mode in which all 
serial data activities are suspended. The Modem Control Register (MCR) along with its 
associated outputs are cleared. The Line Status Register (LSR) is cleared except for the 
THRE and TEMT bits, which are set. All functions of the device remain in an idle state 
until programmed to resume serial data activities. 


Serial Channel Interrupts - Each three-state, serial channel interrupt output (enabled by 
bit 3 of the MCR) goes active (high) when one of the following interrupts has an active 
(high) condition and is enabled by the Interrupt Enable Register of its associated channel: 
Receiver Error flag, Received Data Available, Transmitter Holding Register Empty, and 
Modem Status. The interrupt is reset low upon appropriate service or a reset operation. 


Serial Data Inputs - The serial data inputs move information from the communication line 
or modem to the VL16C452 receiver circuits. A mark (1) is high, and a space (0) is low. 
Data on serial data inputs is disabled when operating in the loop mode. 


Chip Selects - Each Chip Select input acts as an enable for the write and read signals 
for the serial channels O (-CSO) and 1 (-CS1). -CS2 enables the the signals to the line 
printer port. 


Bus Buffer Output - This active high output is asserted when either serial channel or the 
parallel port is read. This output can be used to control the system bus driver device 
(74LS245). 


Parallel Data Bits (O-7) - These eight lines provide a byte-wide input or output port to the 
system. The eight lines are held in a high-impedance state when -LPTOE is held in the 
high state. 


Line Printer Strobe - This open-drain line provides communication between the 
VL16C452 and the line printer. When it is active low, it provides the line printer with a 
signal to latch the data currently on the parallel port. 


Line Printer Autofeed - This open-drain line provides the line printer with an active low 
signal when continuous form paper is to be autofed to the printer. 


Line Printer Initialize: This open-drain line provides the line printer with a signal that 
allows the line printer initialization routine to be started. 


Line Printer Select: This open-drain line selects the printer when it is active low. 


Printer Port interrupt - This signal is an active high, three-state output, generated by the 
positive transition of -ACK. It is enabled by bit 4 of the Write Control Register. 


Line Printer Error - This is an input line from the line printer. The line printer reports an 
error by holding this line low during the error condition. 


Line Printer Selected - This is an input line from the line printer that goes high when the 
line printer has been selected. 
, 


Line Printer Busy - This is an input line from the line printer that goes high when the line 
printer is not ready to accept data. 


Line Printer Paper Empty - This is an input line from the line printer that goes high when 
the printer runs out of paper. 


Line Printer Acknowledge - This input goes low to indicate a successful data transfer has 
taken place. it generates a printer port interrupt during its positive transition. 


83 


® VLSI TECHNOLOGY, INC. 
VL16C452 


FUNCTIONAL 
DESCRIPTION: 
SERIAL CHANNEL REGISTERS 
Three types of internal registers are 
used in each serial channel of the 
VL16C452. They are used in the 
operation of the device, and are the 
control, status, and data registers. The 
control registers are the Bit Rate Select 
Register DLL (Divisor Latch LSB) and 
DLM (Divisor Latch MSB), Line Control 
Register, Interrupt Enable Register, and 
the Modem Control registers, while the 
status registers are the Line Status 
Registers and the Modem Status 
Register. The data registers are the 
Receiver Buffer Register and the 
Transmitter Holding Register. The 
Address, Read, and Write inputs are 
used in conjunction with the Divisor 
Latch Access Bit in the Line Control 
Register [LCR(7)] to select the register 
to be written or read (see Table 1). 
Individual bits within these registers are 
referred to by the register mnemonic 
and the bit number in parenthesis. An 
example, LCR(7) refers to Line Control 
Register Bit 7. 


The Transmitter Buffer Register and 
Receiver Buffer Register are data 
registers holding from five to eight bits 
of data. If less than eight data bits are 
transmitted, data is right justified to the 


LSB. Bit 0 of a data word is always the 
first serial data bit received and 
transmitted. The VL16C452 data 
registers are double-buffered so that 
read and write operations can be 
performed at the same time the UART 
is performing the parallel-to-serial and 
serial-to-parallel conversion. 


The format of the data character is 
controlled by the Line Control Register. 
The contents of the LCR may be read, 
eliminating the need for separate 
storage of the line characteristics in 
system memory. The contents of the 
LCR are described below: 


LCR (0) Word Length Select Bit 0 
(WLSO) 
LCR (1) Word Length Select Bit 1 
(WLS1) 
LCR (2) Stop Bit Select (STB) 
LCR (3) Parity Enable (PEN) 
LCR (4) Even Parity Select (EPS) 
LCR (5) Stick Parity 
LCR (6) Set Break 
LCR (7) Divisor Latch Access Bit 
(DLAB) 


LCR (0) and LCR(1) word length select 
bit 1: The number of bits in each serial 
character is programmed as shown in 
the following chart: 


TABLE 1 . SERIAL CHANNEL INTERNAL REGISTERS 


RBR 
M mmm@ 
0 
o 
0 
0 


0 
0 
0 
0 
THR 


0 
0 
1 
IER 


o 
1 
0 
IIR 


o 
1 
1 
LCR 


1 
0 
0 
MCR 


1 
:0 
1 
LSR 


-"'><><><><><><° 
Q 


1,10 
MSR 


1 
1 
1 
SCR 


0 
0 
DLL 


1 
0 
0 
1 
DLM 


Register 


Receiver Buffer Register (read only) 


Transmitter Holding Register (write only) 


Interrupt Enable Register 


Interrupt Identification Register (read only) 


Line Control Register 


Modem Control Register 


Line Status Register 


Modem Status Register 


Scratch Register 


Divisor Latch (LSB) 


Divisor Latch (MSB) 


X - "Don’t Care” 
0 -= Logic Low 
1 -= Logic High 
Note: Serial Channel 0 is accessed when -CSO is low; Serial Channel 1 is accessed 
when -CS1 is low. Selecting both channels simultaneously is an invalid condition. 
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LCR(1) 
LCR(0) 
Word Length 


5 Bits 
6 Bits 
7 Bits 
8 Bits 
--~00 


LCR(2) Stop Bit Select: LCR(2) 
specifies the number of stop bits in each 
transmitted character. If LCR(2) is a 
logic O, one stop bit is generated in the 
transmitted data. If LCR(2) is a logic 1 
when a 5-bit word length is selected, 1.5 
stop bits are generated. If LCR(2) is a 
logic 1 when either a 6-, 7-, or 8-bit word 
length is selected, two stop bits are 
generated. The receiver checks for two 
stop bits if programmed. 


LCR(3) Parity Enable: When LCR(3) is 
high, a parity bit between the last data 
word bit and stop bit is generated and 
checked. 


LCR(4) Even Parity Select: When parity 
is enabled [LCR(3)=1], LCR(4)-0 selects 
odd parity, and LCR(4)-1 selects even 
parity. 


LCR(5) Stick Parity: When parity is 
enabled [LCR(3)-1], CLR(5)=1 causes 
the transmission and reception of a 
parity bit to be in the opposite state from 
that indicated by LCR(4). This allows 
the user to force parity to a known state 
and for the receiver to check the parity 
bit in a known state. 


LCR(6) Break Control: When LCR(6) is 
set to a logic "1", the serial output 
(SOUT) is forced to the spacing (logic 0) 
state. -The break is disabled by setting 
LCR(6) to alogic "0". The Break Control 
bit acts only on SOUT and has no effect 
on the transmitter logic. Break Control 
enables the CPU to alert a terminal in a 
computer communications system. If 
the following sequence is used, no 
erroneous or extraneous characters will 
be transmitted because of the break. 


1. Load an all "0"s pad character in 
response to THRE. 


2. Set break in response to the next 
THRE. 


3. Wait for the transmitter to be idle 
(TEMT-1), and clear break when 
normal transmission has to be 
restored. 


S) 


FIGURE .1. UNE CONTROL REGISTER 
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LCR 
LCR 
LCR 
LCR 
LCR 
LCR 
LCR 
LCR 
7 
6 
5 
4 
3 
2 
1 
0 


O 
O 


VL16C452 


= 
5 Data Bits 
Word 
= 
6 Data Bits 
Length 
= 1 Data Bits 
Select 
= e Data Bits 
-540 
_;Q_; 


Stop 
O = 
1 Stop Bit 
Bit Select 
1 = 1.5 Stop Bits If 5 Data Bits Selected 
2 Stop Bits if 6, 7, 8 Data Bits Selected 
Parity 
0 = Parity Disabled 
Enable 
1 = Parity Enabled 


Even 
0 = Odd Parity 
Parity 
1 = Even Parity 
Select 


Stick 
0 = Stick Parity Disabled 
Parity 
1 = Stick Parity Enabled 


Break 
O = Break Disabled 
Control 
1 = Break Enabled 


Divisor 
0 
Access Receiver Buffer 
Latch 
1 = Access Divisor Latches 
Access 
Bit 


LCR(7) Divisor Latch Access Bit 
(DLAB): LCR(7) must be set high (logic 
'1") to access the Divisor Latches DLL 
and DLM of the Baud Rate Generator 
during a read or write operation. 
LCR(7) must be input low to access the 
Receiver Buffer, the Transmitter 
Holding, or the Interrupt Enable 
Registers. 


The Line Status Register (LSR) is a 
single register that provides status 
indications. The LSR is usually the first 
register read by the CPU to determine 
the cause of an interrupt or to poll the 
status of each serial channel of the 
VL16C452. 


Three error flags OE, FE, and PE 
provide the status of any error condi- 
tions detected in the receiver circuitry. 
During reception of the stop bits, the 
error flags are set high by an error 
condition. The error flags are not reset 
by the absence of an error condition in 
the next received character. The flags 
reflect the last character only if no 
overrun occurred. The Overrun Error 


character in the Receiver Buffer 
Register has been overwritten by a 
character from the Receiver Shift 
Register before being read by the CPU. 
The character is thereby lost. Framing 
Error (FE) indicates that the last 
character received contained incorrect 
(low) stop bits. This is caused by the 
absense of the required stop bit or by a 
stop bit too short to be detected. Parity 
Error (PE) indicates that the last 
character received had a parity error 
based on the programmed and calcu- 
lated parity of the received character. 


The Break Interrupt (Bl) status bit 
indicates that the last character 
received was a break character. A 
break character is an invalid data 
character. However, it is an entire 
character, including parity and stop bits. 


The Transmitter Holding Register 
Empty (THRE) bit indicates that theTHR 
register is empty and may receive 
another character. The Transmission 
Shift Register Empty (TEMT) bit 
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indicates that the Transmitter Shift 
Register is empty, and the serial 
channel has completed transmission of 
the last charactertc be sent. If the 
interrupt is enabled [IER(1)]. an active 
THRE causes an interrupt (INTRPT). 


The Data Ready (DR) bit indicates that 
the RBR has been loaded with a 
received character (including Break) 
and that the CPU may access this data. 


Reading the LSR clears LSR(1)- 
LSR(4). (OE, PE, FE, and Bl.) 


The contents of the Line Status 
Register shown in Table 2 are de- 
scribed below: 


LSR(0) Data Ready (DR): Data Ready 
is set high when an incoming character 
has been received and transferred into 
the Receiver Buffer Register. LSR(O) is 
reset low by a CPU read of the data in 
the Reciever Buffer Register. 


LSR(1) Overrun Error (OE): Overrun 
Error indicates that data in the Receiver 
Buffer Register was not read by the 
CPU before the next character was 
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TABLE 2. LINE STATUS REGISTER BITS 


LSR BITS 


LSR(O) Data Ready(DR) 


LSR (1) Overrun Error (OE) 


LSR(2) Parity Error (PE) 


LSR (3) Framing Error (FE) 


LSR (4) Break Interrupt (Bl) 


LSR (5) Transmitter Holding Register Empty (Ti-IRE) 
Empty 
- 


LSR (6) Transmitter Empty (TEMT) 


LSR (7) Not Used 


Loglc 1 
Loglc 0 


Ready 
Not Ready 


Error 
No Error 


Error 
No Error 


No Error 


No Break 


Not Empty 


Not Empty 


Error 


Break 


Empty 


transferred into the Receiver Buffer 
Register, overwriting the previous 
character. The OE indicator is reset 
whenever the CPU reads the contents 
of the Line Status Register. 


LSR(2) Parity Error (PE): Parity Error 
indicates that the received data 
character does not have the correct 
even or odd parity, as selected by the 
Even Parity Select bit (LCR(4)). The 
PE bit is set high upon detection of a 
parity error, and is reset low when the 
CPU reads the contents of the LSR. 


LSR(3) Framing Error (FE): Framing 
Error indicates that the received 
character did not have a valid stop bit. 
LSR(3) is set high when the stop bit 
following the last data bit or parity bit is 
detected as a zero bit (spacing level). 
The FE indicator is reset low when the 
CPU reads the contents of the LSR. 


LSR(4) Break Interrupt (Bl): Break 
Interrupt is set high when the received 
data input is held in the spacing (logic 
0) state for longer than a full word 
transmission time (start bit + data bits + 
pairty + stop bits). The Bl indicator is 
reset when the CPU reads the contents 
of the Line Status Register. 


LSR(1) - LSR(4) are the error condi- 
tions that produce a Reciever Line 
Status interrupt (priority 1 interrupt in 
the Interrupt Identification Register 
(llR)) when any of the conditions are 
detected. This interrupt is enabled by 
setting iER(2)=1 in the Interrupt Enable 
Register. 


LSR(5) Transmitter Holding Register 
Empty (THRE): THRE indicates that 
the VL82C50A is ready to accept a new 
character for transmission. The THRE 


bit is set high when a character is 
transferred from the Transmitter 
Holding Register into the Transmitter 
Shift Register. LSR(5) is reset low by 
the loading of the Transmitter Holding 
Register by the CPU. LSR(5) is not 
reset by a CPU read of the LSR. 


When the THRE interrupt is enabled 
(lER(1)=-1). THRE causes a priority 3 
interrupt in the IIR. if THRE is the 
interrupt source indicated in IIR, 
INTRPT is cleared by a read of the IIR. 


LSR(6) Transmitter Empty (TEMT): 
TEMT is set high when the Transmitter 
Holding Register (THR) and the 
Transmitter Shift Register (TSR) are 
both empty. LSR(6) is reset low when 
a character is loaded into the THR and 
remains low until the character is 
transferred out of SOUT. TEMT is not 
reset low by a CPU read of the LSR. 


LSR(7): This bit is always 0. 


The Modem Control Register (MCR) 
controls the interface with the modem 
or data set as described in Table 3. 


VL1 6C452 


MCR can be written and read. The 
-RTS and -DTR outputs are directly 
controlled by their control bits in this 
register. A high input asserts a low 
(true) at the output pins. MCR Bits 0, 1, 
3, and 4 are shown below: 


MCR(O): When MCR(O) is set high, the 
-DTR output is forced low. When 
MCR(O) is reset low, the -DTR output is 
forced high. The -DTR output of the 
serial channel may be input into an 
inverting line driver in order to obtain 
the proper polarity input at the modem 
or data set. 


MCR(1): 
I When MCR(1) is set high, the 
RTS output is forced low. Whe MCR(1) 
is reset low, the -RTS output is forced 
high. The -RTS output of the serial 
channel may be input into an inverting 
line driver in order to obtain the proper 
polarity input at the modem or data set. 


MCR(3): When MCR(3) is set high, the 
INT output is enabled. 


MCR(4): MCR(4) provides a local 
loopback feature for diagnostic testing 
of the channel. When MCR(4) is set 
high, Serial Output (SOUT) is set to the 
marking (logic "1 ") state, and the 
receiver data input Serial Input (SIN) is 
disconnected. The output of the 
Transmitter Shift Register is looped 
back into the Receiver Shift Register 
input. The three modem control inputs 
(—CTS, -DSR, and -RI) are discon- 
nected. The modem control outputs 
(-DTR and -RTS) are internally con- 
nected to the four modem control 
inputs. The modem control output pins 
are forced to their inactive state (high). 


TABLE 3. MODEM CONTROL REGISTER BITS 
MCR BITS 
Logic 1 
Loglc 0 


MCR (O) DataTerminal Ready (DTR) 
-DTR Output Low 
-DTR Output High 


MCR (1) Request to Send (RTS) 
-RTS Output Low 
—RTS OutputHigh 
MCR (2) 0 


MCR (3) Interrupt (INT) Enable 
INT Enabled 
INT Disabled 


MCR (4) LOOP 
Loop Enabled 
Loop Disabled 
MCR (5) o 
MCR (6) 0 
MCS (7) 0 
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FIGURE 2. MODEM CONTROL REGISTER 


Modem Control Register (MCR) 


MCR MCR MCR MCR MCR MCR MCR MCR 
7 
6 
5 
4 
3 
2 
1 
0 


Data 
O 
Terminal 
1 
Ready 


Request 
0 
To Send 
1 


NC 


INT 
0 


1 


LOOP 


--o 


VL16C452 


-DTR Output High (Inactive) 
-DTR Output Low (Active) 


—RTS Output High (inactive) 
—RTS Output Low (Active) 


Not Connected 


INT Disabled 
INT Enabled 


LOOP Disabled 
LOOP Enabled 


These Bits are Permanently Set to Logic "0". 


In the diagnostic mode, data transmit- 
ted is immediately received. This 
allows the processor to verify the 
transmit and receive data paths of the 
selected serial channel. Bits MCR(5) - 
MCR(7) are permanently set to logic O. 


The MSR provides the CPU with status 
of the modem input lines from the 
modem or peripheral devices. The MSR 
allows the CPU to read each of the 
serial channel modem signal inputs by 
accessing the data bus interface of the 
VL16C452. In addition to the current 
status information, four bits of the MSR 
indicate whether the modem inputs have 
changed since the last reading of the 
MSR. The delta status bits are set high 
when a control input from the modem 
changes state, and reset low when the 
CPU reads the MSR. 


The modem input lines for each channel 
are -CTS, -DSR, -RI, and -RLSD. 
MSR(4) - MSR(7) are status indications 
of these lines. The status indications 
follow the status of the input lines. if the 
modem status interrupt in the Interrupt 
Enable Register is enabled [lER(3)], a 
change of state in a modem input 
signals will be reflected by the modem 
status bits in the IIR register, and an 
interrupt (INTRPT) is generated. The 
MSR is a priority 4 interrupt. The 
contents of the Modem Status Register 
are described in Table 4. Note that the 
state (high or low) of the status bits are 


inverted versions of the actual input 
pins. 


MSR(0) Delta Clear to Send (DCTS): 
DCTS indicates that the —CTS input to 
the serial channel has changed state 
since the last time it was read by the 
CPU. 


MSR(1) Delta Data Set Ready (DDSR): 
DDSR indicates that the -DSR input to 
the serial channel has changed state 
since the last time it was read by the 
CPU. 


MSR(2) Trailing Edge of Ring Indicator 
(TERI): TERI indicates that the -RI 
input to the serial channel has changed 
state from high to low since the last 
time it was read by the CPU. Low to 
high transitions on —Rl do not activate 
TERI. 


MSR(3) Delta Data Carrier Detect 
(DRSLD): DRSLD indicates that the 


-RSLD input to the serial channel has 
changed state since the last time it was 
read by the CPU. 


MSR(4) Clear to Send (CTS): Clear to 
Send (CTS) is the status of the —CTS 
input from the modem indicating to the 
serial channel that the modem is ready 
to receive data from the serial channel's"I 
transmitter output (SOUT). If the serial 
channel is in loop mode [MSR(4)-1], 
MSR(4) is equivalent to —RTS in the 
MCR. 


MSR(5) Data Set Ready (DSR): Data 
Set Ready (DSR) is a status of the 
-DSR input from the modem to the 
serial channel which indicates that the 
modem is ready to provide received 
data to the serial channel receiver 
circuitry. If the channel is in the loop 
mode [MCR(4)-=1], MSR(5) is equiva- 
lent to the DTR in the MCR. 


TABLE 4. MODEM STATUS REGISTER BITS 
MSR an 
Description 


MSR 
MSR 
MSR 
MSR 
MSR 
MSR 
MSR 
MSR 


(1) 
DDSR 
Delta Data Set Ready 
(2) 
TERI 
Trailing Edge of Ring Indicator 
(0) 
DCTS 
Delta Clear to Send 
(3) 
DRLSD 
Delta Data Carrier Detect 
(4) 
-CTS 
Clear To Send 
(5) 
-DSR 
Data Set Ready 
(6) 
-RI 
Ring Indicator 
(7) 
-RLSD 
Receiver Line Signal Detect 
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MSR(6) Ring Indicator: Indicates the 
status fo the RI input (pin 39). If the 
channel is in _the loop mode 
[MCR(4)=1], MSR(6) is not connected 
in the MCR. 


MSR(7) Receive Line Signal Detect : 
Receive Line Signal Detect indicates 
the status of the Receive Line Signal 
Detect (-RLSD) input . If the channel is 
in the loop mode [MCR(4)-1], MSR(4) is 
equivalent to OUT2 of the MCR. 


The modem status inputs (—Rl, -RLSD, 
—DSR, and —CTS) reflect the modem 
input lines with any change of status. 
Reading the MSR register will clear the 
delta modem status indications but has 
no effect on the status bits. The status 
bits reflect the state of the input pins 
regardless of the mask control signals. 
If a DCTS, DDSR, TERI, or DRLSD are 
true, and a state change occurs during 
a read operation (—lOR), the state 
change is not indicated in the MSR. If 
DCTS, DDSR, TERI, or DRLSD are 
false, and a state change occurs during 
a read operation, the state change is 
indicated after the read operation. 


For LSR and MSR, the setting of status 
bits is inhibited during status register 
read -IOR operations. If a status 
condition is generated during a read 
—lOR operation, the status bit is not set 
until the trailing edge of the read 
-IOR. 


If a status bitis set during a read 
—lOR operation, and the same status 
conditionoccurs, that status bit will be 
cleared at the trailing edge of the read 
—lOR instead of being set again. 


Each VL16C452 serial channel contains 
a programmable Baud Rate Generator 
(BRG) that divides the clock (DC to 
3.1 MHz) by any divisorfrom 1 to 2 "i" 
(see also BRG description). The output 
frequency of the Baud Generator is 16X 
the data rate [divisor # = clock + (baud 
rate x 16)]. Two 8-bit divisor latch 
registers store the divisor in a 16-bit 
binary format. These Divisor Latch 
registers must be loaded during 
initialization. Upon loading either of the 
Divisor latches, a 16-bit baud counter is 
immediately loaded. This prevents long 
counts on initial load. 


The receiver circuitry in each serial 
channel ofthe VL16C452 is program- 
mable for 5, 6, 7, or 8 data bits per 


character. For words of less than 8 
bits, the data is right justified to the 
least significant bit LSB = Data Bit 0 
[RBR(O)]. Data Bit 0 of a data word 
[RBR(0)] is the first data bit received. 
The unused bits in a character less than 
8 bits are output low to the parallel 
output by the serial channel. 


Received data at the SIN input pin is 
shifted into the Receiver Shift Register 
by the 16X clock provided at the RCLK 
input. This clock is synchronized to the 
incoming data based on the position of 
the start bit. When a complete charac- 
ter is shifted into the Receiver Shift 
Register, the assembled data bits are 
parallel loaded into the Receiver Buffer 
Register. The DR flag in the LSR 
register is set. 


Double buffering of the received data 
permits continuous reception of data 
without losing received data. While the 
Receiver Shift Register is shifting a new 
character into the serial channel, the 
Receiver Buffer Register is holding a 
previously received character for the 
CPU to read. Failure to read the data in 
the RBR before complete reception of 
the next character result in the low of 
the data in the Receiver Register. The 
OE flag in the LSR register indicates 
the overrun condition. 


RBR Bits 0 thru 7: 


THR Bits 0 thru 7 


THR(0) 
Data Bit 0 
THRU) 
THRQ) 
THRG) 
THRM) 
THR6) 
THR@) 
THRU) 


DmaBh1 
DmaBh2 
DmaBh3 
DmaBH4 
DmaBh5 
DmaBh6 
DmaBh7 


Scratchpad Register is an 8-bit Read/ 
Write register that has no effect on any 
channel in the VL16C452. It is intended 
to be used by the programmer to hold 
data termporarily. 


SCR Bits 0 thru 7 
scam) 
scan) 
scam) 
scam) 
scam) 
soap) 
scam) 
scan) 


Data Bit 0 
DmaBh1 
DmaBh2 
DmaBh3 
DmaBh4 
DmaBh5 
DmaBh6 
DmaBh7 


Ream) 
RBRU) 
RBRQ) 
RBRB) 
RBRM) 
RBR6) 
RBR@) 
RBRU) 


DmaBh0 
DmaBh1 
DmaBh2 
DmaB3 
DmaBh4 
DmaBh5 
DmaBh6 
DmaBh7 


The Transmitter Holding Register (Tl-IR) 
holds parallel data from the data bus 
(D0-D7) until the Transmitter Shift 
Register is empty and ready to accept a 
new character for transmission. The 
transmitter and receiver word length 
and number of stop bits are the same. 
If the character is less than eight bits, 
unused bits at the microprocessor data 
bus are ignored by the transmitter. 


Data Bit 0 [THR(0)] is the first serial 
data bit transmitted. The THRE flag 
[LSR(5)] reflect the status of the THR. 
The TEMT flag [LSR(5)] indicates if 
both the THR and TSR are empty. 


INTERRUPTS 
The Interrupt Identification Register 
(IIR) of each serial channel of the 
VL16C452 has interrupt capability for 
interfacing to current microprocessors. 
In order to minimize software overhead 
during data character transfers, the 
serial channel prioritizes interrupts into 
four levels. The four levels of interrupt 
conditions are as follows: 


1. Receiver Line Status (priority 1) 
2. Received Data Ready (priority 2) 
3. Transmitter Holding Register Empty 
(priority 3) 
4. Modem Status (priority 4) 


information indicating that a prioritized 
interrupt is pending and the type of 
interrupt is stored in the Interrupt 
Identification Register (IIR). When 
addressed during chip select time, the 
IIR indicates the highest priority 
interrupt pending. No other interrupts 
are acknowledged until the interrupt is 
serviced by the CPU. The logic equiva- 
lent of the interrupt control circuit is 
shown in Figure 3. The contents of the 
IIR are indicated in Table 5 and are 
described below. 


lIR(0): llR(0) can be used in either a 
hard-wired prioritized or polled environ- 
ment to ‘indicate whether an interrupt is 
pending. When IlR(0) is low, an 
interrupt is pending, and IIR contents 
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TABLE 5. INTERRUPT IDENTIFICATION REGISTER 


INTERRUPT IDENTIFICATION 
INTERRUPT SET AND RESET FUNCTIONS 


Priority 
interrupt 
Interrupt 
Interrupt 


X 
X 
1 
None 
None 


1 
1 
0 
First 
Receiver 
OE, PE 
LSR Read 
Line Status 
FE, or Bl 


1 
0 
0 
Second 
Received Data 
Received Data 
RBR Read 
Available 
Available 


0 
1 
0 
Third 
THRE 
THRE 
IIR Read if THRE is the 
Interrupt Source or THR Write 


0 
0 
0 
Fourth 
Modem Status 
—CTS, -DSR 
MSR Read 
—Rl, -RSLD 


X - Not Defined. 


FIGURE 3. INTERRUPT CONTROL LOGIC 


DR (LSR BIT 0 
. 
ERBFI (IER err o 


THRE (|_sr=1 BIT s 
ETBEI (IER BIT1 
D 
D 
INTERRUPT 
OUTPUT 
OE (LSR err 1) 
PE (LSR en" 2) 
FE (LSR err 3) 
) . 
er (|_sr=1 BIT 4) 
ELSI (IER err 1) 
cots (MSR an o 
oosn (MSR BIT1 
D 


TERI (MSR BIT 2) 
. 
DDCD (MSR BIT 3 


EDSSI (IER BIT 3) 


Interrupt Enable (MCR BIT 3) 
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TABLE 6. SERIAL CHANNEL ACCESSIBLE REGISTERS 


Register 
Register Bit Number 


VL1 6C452 


y 
RBR 
Data 
(Read Only) 
Bit 7 


THR 


(MSB) 


Data 
(Write Only) 
Bit 7 


DLL 


DLM 


Bit7 


Bit 15 


IER 
0 


IIR 
0 
(Read Only) 


LCR 


MCR 


LSR 


MSR 


SCR 


(DLAB) 
Divisor 
Latch 
Access 
Bit 


0 


Data 
Bit 6 


Data 
Bit 6 


Bit 6 


Bit 14 


0 


0 


Set 
Break 


0 


I Data 
Bit 5 


Data 
Bit 5 


Bit 5 


Bit 13 


0 


0 


Stick 
Parity 


0 


0 
(TEMT) 
(THRE) 
Transmitter 
Transmitter 
Empty 
Holding 
Register 
Empty 


(DCD) 
(RI) 
(DSR) 
Data 
Ring 
Data 
Carrier 
Indicator 
Ready 
Detect 
Set 


Bit 7 
‘Bit 6 
Bit 5 


‘LSB Data Bit 0 is the first bit transmitted or received. 


Data 
Bit 4 


Data 
Bit 4 


Bit 4 


Bit 12 


0 


0 


(EPS) 
Even 
Parity 
Select 


Loop 


(Bl) 
Break 
Interrupt 


Data 
Bit 3 


Data 
Bit 3 


ens 


Bit11 


(Eossn 
Enable 
Modem 
Status - 
Interrupt 


0 


(PEN) 
Parity 
Enable 


Out 2 


(FE) 
Framing 
Error 


Data 
Bit 2 


Data 
Bit 2 


Bit2 


Bit 10 


(ELSD 
Enable 
Receiver 
Line 
Status 
Interrupt 


Interrupt 
ID 
Bit (1) 


(STB) 
Number 
of Stop 
Bits 


Out 1 


(PE) 
Parity 
Error 


(CTS) 
(DRSLD) 
(TERI) 
Clear 
Delta 
Trailing 
to 
Send 
Line Signal 
Receive 


Detect 


Edge. 
Ring 
Indicator 


Bit 4 
Bit 3 
Bit 2 
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Data 
Bit 1 


Data 
Bit 1 


Bit 1 


Bit 9 


(ETBEI) 
Enable 
Transmitter 
Holding 
Register 
Empty 
Interrupt 


Interrupt 
ID 
Bit (0) 


(WLSB1) 
Word 
Length 
Select 
Bit 1 


(RTS) 
Request 
To 
Send 


(0E) 
Overrun 
Error 


(DDSR) 
Delta 
Data 
Set 
Ready 


Bit 1 


Data _ 
Bit 0 
(LSB)' 


Data 
Bit 0 


Bit0 


Bit8 


(ERBFI) 
Enable 
Received 
Data 
Available 
Interrupt 


"0' 1F 
Interrupt 
Pending 


(WLSBO) 
Word 
Length 
Select 
Bit 0 


(DTR) 
Data 
Terminal 
Ready 


(DR) 
Data 
Ready 


(DCTS) 
Delta 
Clear 
-to 
Send 


BitO 


may be used as a pointer to the appro- 
priate interrupt service routine. When 
llR(0) is high, no interrupt is pending. 


llR(1) and llR(2) are used to identify the 
highest priority interrupt pending as 
indicated in Table 2. 


llR(3) - llR(7): These five bits of the IIR 
are logic 0. 


The Interrupt Enable Register (IER) is a 
Write register used to independently 
enable the four serial channel interrupts 
which activate the interrupt (INTRPT) 
output. All interrupts are disabled by 
resetting lER(0) - lER(3) of the Interrupt 
Enable Register. interrupts are enabled 
by setting the appropriate bits of the IER 
high. Disabling the interrupt system 
inhibits the interrupt Identification 
Register and the active (high) INTRPT 
output. All other system functions 
operate in their normal manner, includ- 
ing the setting of the Line Status and 
Modem Status Registers. The contents 
of the Interrupt Enable Register is de- 
scribed in Table 3 and below: 


lER(0): When programmed high 
[lER(0)-=Logic 1], lER(0) enables 
Received Data Available interrupt. 


IER(1): When programmed high 
[IER(1)-=Logic 1], IER(1) enables the 
Transmitter Holding Register Empty 
interrupt. 


lER(2): When programmed high 
[lER(2)=Logic 1], lER(2) enables the 
Receiver Line Status interrupt. 


lER(3): When programmed high 
[IER(3)=-Logic 1], lER(3) enables the 
Modem Status Interrupt. 


lER(4) - lER(7): These four bits of the 
IER are logic 0. 


TRANSMITTER 
The serial transmitter section consists of 
a Transmitter Holding Register (THR), 
Transmitter Shift Register (TSR), and 
associated control logic. The Transmit- 
ter Holding Register Empty (THRE) and 
Transmitter Shift Register Empty 
(TEMT) are two bits in the Line Status 
Register which indicate the status of 
THR and TSR. To transmit a 5- to 8-bit 
word, the word is written through DO-D7 
to the THR. The microprocessor should 
perform a write operation only if THRE is 
high. The THRE is set high when the 
word is automatically transferred from 
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the THR to the TSR during the transmis- 
sion of the start bit. 


When the transmitter is idle, THRE and 
TEMT are high. The first word written 
causes THRE to be reset to 0. After the 
transfer, THRE returns high. TEMT 
remains low for at least the duration of 
the transmission of the data word. If a 
second character is transmitted to the 
THR, the THRE is reset low. Since the 
data word cannot be transferred from the 
THR to the TSR until the TSR is empty, 
THRE remains low until the TSR has 
completed sending the word. When the 
last word has been transmitted out of the 
TSR, TEMT is set high. THRE is set 
high one THR to TSR transfer time later. 


RECEIVER 
Serial asynchronous data is input into 
the SIN pin. The idle state of the line 
providing the input into SIN is high. A 
start bit detect circuit continually 
searches for a high to low transition from 
the idle state. When the transition is 
detected, a counter is reset, and counts 
the 16X clock to 7 1/2, which is the 
center of the start bit. The start bit is 
valid if the SIN is still low at the mid-bit 
sample of the start bit. Verifying the 
start bit prevents the receiver from 
assembling a false data character due to 
a low going noise spike on the SIN input. 


The Line Control Register determines 
the number of data bits in a character 
(LCR(O), LCR(1)), number of stop bits 
LCR(2), if parity is used LCR(3), and the 
polarity of parity LCR(4). Status for the 
receiver is provided in the Line Status 
Registerto the Receiver Buffer Register, 
the Data Received indication in LSR(O) 
is set high. The CPU reads the Receiver 
Buffer Register through DO-D7. This 
read resets LSR(O). If D0-D7 are not 
read prior to a new character transfer 
from the RSR to the RBR, the overrun 
error status indication is set in LSR(1). 
The parity check tests for even or odd 
parity on the parity bit, which precedes 
the first stop bit. If there is a parity error, 
the parity error is set in LSR(2). There is 
circuitry which tests whether the stop bit 
is high. If it is not, a framing error 
indication is generated in LSR(3). 


The center of the start bit is defined as 
clock count 7 1/2. If the data into SIN is 
symmetrical square wave, the center of 
the data cells will occur within 
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+/- 3.125% of the actual center, 
providing an error margin of 46.875%. 
The start bit can begin as much as one 
16X clock cycle prior to being detected. 


BAUD RATE GENERATOR (BRG) 
The BRG generates the clocking for the 
UART function, providing standard 
ANSI/CClTl' bit rates. The oscillator 
driving the BRG is provided by an 
external clock into CLK. 


The data rate is determined by the 
Divisor Latch registers DLL and DLM 
and the external frequency. The bit rate 
is selected by programming the two 
divisor latches, Divisor Latch Most 
Significant Byte and Divisor Latch Least 
Significant Byte. Setting DLL=1 and 
DLM=0 selects the divisor to divide by 1 
(divide by 1 gives maximum baud rate 
for a given input frequency at the CLK 
input). 


The BRG can use any of three different 
popular frequencies to provide standard 
baud rates. These frequencies are 
1.8432 MHz, 2.4576 MHz, and 3.072 
MHz. With these frequencies, standard 
bit rates from 50 to 38.5 kbps are 
available. Tables 7, 8, and 9 illustrate 
the divisors needed to obtain standard 
rates using these three crystal frequen- 
CIBS. 


RESET 
After power up, the VL16C452 -RESET 
input should be held low for 500 ns to 
reset the VL16C452 circuits to an idle 
mode until initialization. A low on 
-RESETcauses the following: 


1. Initializes the transmitter and 
receiver internal clock counters. 


2. Clears the Line Status Register 
(LSR), except for Transmitter Shift 
Register Empty (TEMT) and 
Transmit Holding Register Empty 
(THRE), which are set. The Modem 
Control Register (MCR) is also 
cleared. All of the discrete lines, 
memory elements and miscellane 
ous logic associated with these 
register bits are also cleared or 
turned off. The Line Control 
Register (LCR), Divisor Latches, 
Receiver Buffer Register, Transmit 
ter Buffer Register are not effected. 


Following removal of the reset condition 
(Reset high), the VL16C452 remains in 
the idle mode until programmed. 
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A hardware reset of the VL16C452 sets 
While the control register can be written 
the THRE and TEMT status bit in the 
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in any order, the IER should be written 
LSR. When interrupts are subsequently 
to last because it controls the interrupt 
enabled, an interrupt occurs due to 
THRE. 


A summary of the effect of a reset on 
the VL16C452 is given in Table 10. 


PROGRAMMING 
Each serial channel of the VL16C452 is 
programmed by the control registers 
LCR, IER, DLL and DLM, and MCR. 
These control words define the charac- 
ter length, number of stop bits, parity, 
baud rate, and modem interface. 


enables. Once a serial channel is 
programmed and operational, these 
registers can be updated any time the 
VL16C452 serial channel is not 
transmitting or receiving data. 


The control signals required to access 
each serial channel's internal registers 
are shown below. 


SOFTWARE RESET 
A software reset of the serial channel is 
a useful method for returning to a 
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completely known state without a 
system reset. Such a reset consists of 
writing to the LCR, Divisor Latches, and 
MCR registers. The LSR and RBR 
registers should be read prior to 
enabling interrupts in order to clear out 
any residual data or status bits which 
may be invalid for subsequent 
operation. 


CLOCK INPUT OPERATION 
The maximum input frequency of the 
external clock of the VL16C452 is 3.1 
MHz. 


TABLE 7. BAUD RATES (1 .8432 MHZ CLOCK) 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 
56000 


2304 


1 536 


1 047 
857 
768 
384 


1 92 
96 
64 
58 
48 
32 
24 


1 6 


1 2 
6 
3 
2 


0.026 
0.058 


0.69 


2.86 
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50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 


50 
75 
110 
13415 
150 
300 
600 
1200 
1800 
2000 
2400 
3600 
4800 
7200 
9600 
19200 
38400 


TABLE 8. BAUD RATES (2.4576 MHZ CLOCK) 


3072 
2048 
1396 
1142 
1024 
512 
256 
128 
85 
77 
64 
43 
32 
21 
16 
8 
4 


TABLE 9. BAUD RATES (3.072 MHz CLOCK) 


3840 
2560 
1745 
1428 
1280 
640 
320 
160 
107 
96 
80 
53 
40 
27 
20 
10 
5 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


(L026 
0.0007 


(1392 
(L260 


(L775 


1.587 


Desired 
Divisor Used 
Percent Error 
Baud Rate 
Difference Between 
Desired and Actual 


(L026 
(L034 


(L312 


(L628 


‘L23 


— 
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S) 
VL1 6C452 


Reset Control 


interrupt Enable Register 
Interrupt Identification 


TABLE 10. RESET 


ReglsterlSlgnaI 


Register 
Line Control Register 
MODEM Control Register 
Line Status Register 
MODEM Status Register 


SOUT 
lntrpt (RCVR Errs) 
lntrpt (RCVR Data Ready) 
lntrpt (THRE) 
lntrpt (Modem Status Changes) 
-4Dm2 
—RTS 
-DTR 
-cwn 


DATA _ 
BUS 


ADDR 
BUS 


CTL 
BUS 


DEVICE APPLICATION 


OPTION 
JUMPERS 
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Reset 
Reset 


Reset 
Reset 
Reset 
Reset 


Reset 
Read LSR/Reset 
Read RBR/Reset 
Read IIR/Write THR/Reset 
Read MSR/Reset 
Reset 
Reset 
Reset 
Reset 
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DUAL 
UART AND 
PRINTER 
PORT 
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All Bits Low (O-3 forced and 4-7 permanent) 
Bit 0 is High, Bits 1 and 2 Low 
Bits 3-7 are Permanently Low 


Reset 


All Bits Low 
All Bits Low 
All Bits Low, Except Bits 5 and 6 are High 
Bits 0-3 Low 
Bits 4-7 input Signal 
High 
Low 
Low 
Low 
Low 
High 
High 
High 
High 


1 CHANNELO ‘Kg 


! CHANNEL1 -Q 


PARALLEL 


SERIAL 


BUFFERS 


SERIAL 


BUFFERS 


9—PIN 
UDI 


CONN 


9—PIN 
IIDI 


CONN 


25-PIN 
“DI! 


R/C NET 
CONN 
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FUNCTIONAL 
DESCRIPTION 
PARALLEL PORT REGISTERS 
The VL16C452's parallel port interfaces 
the device to a Centronics-style printer. 
When Chip Select 2 (-CS2) is low, the 
parallel port is selected. Table 11 
shows the registers associated with this 
parallel port. The read or write function 
of the register is controlled by the state 
of the read (-IOR) and write 
(-IOW) pin as shown. The Read Data 
Register allows the microprocessor to 
read the information on the parallel bus. 


The Read Status Register allows the 
microprocessor to read the status of the 
printer in the five most significant bits. 
The status bits are Printer Busy 
(-BUSY), Acknowledge (-ACK) which 
is a handshake function, Paper Empty 
(PE), Printer Selected (SLCT), and 
Error 
(-ERROR). The Read Control Register 
allows the state of the control lines to 
be read. The Write Control Register 
sets the state of the <x>ntrol lines. 


They are interrupt Enable (IRO ENB), 
Select in (SLIN), initialize the Printer 
(-INIT), Autofeed the Paper (AUTOFD), 
Strobe (STROBE), which informs the 
printer of the presence of a valid byte 
on the parallel bus. The Write Data 
Register allows the microprocessor to 
write a byte to the parallel bus. 


The parallel port is completely compat- 
ible with the parallel port implementa- 
tion used in the IBM Serial/Parallel 
Adaptor. 


TABLE 11. PARALLEL PORT REGISTERS 


Register 
Register Bits 


Bit 7 


Read Data 


Read Status 


Read Control 


Write Data 
PD7 


Write Control 


TABLE 12. PARALLEL PORT REGISTER SELECT 
Control Pins 
Register Selected 
III! 
III- 
III!II 
III! 
IIII 
II 
-4-4»»oo 
o-c>6 


ID 


NIM:H:E:UMEIUHENéI 


O(DN 
Read Data 
Read Status 
Read Control 
Invalid 
Write Data 
Invalid 
Write Control 
Invalid 


PD7 


-BUSY 
-ACK 
SLCT 
-ERROR 
1 


Bit 0 


PDO 
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AC CHARACTERISTICS TA: ooc to +7o~c, vcc= s v 15% (Notes 


Symbol 


tDIW 


RC 


tDDD 


tHZ 


tDOW 


WC 


tDS 


tDH 


tRA 


tRCS 


tAR 


tCSR 


tWA 


tWCS 


tAW 


tCSW 


tRW 


tXH 


tXL 


Notes 


1. All timing specifications apply to pins on both serial channels (e.g. RI refers to both RIO and RI1). 
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. 
°- ..6 


3 


oonoo 


nl 


1‘ 
O N 


Parameter 
- 
Strobe Width 


Read Cyle 


Delay from -IOR to Data 


-IOR to Floating Data Delay 


-IOW Strobe Width 


Write Cycle 


Data Setup Time 


Data Hold Time 


Address Hold Time from -IOR 


Chip Select Hold Time from -IOR 


-IOR Delay from Address 


-IOR Delay from Chip Select 


A dress Hold Time from—IOW 


Chip Select Hold Time from -IOW 


-IOW Delay from Address 


-IOW Delay from Select 


Reset Pulse Width 


Duration of Clock High Pulse 
£11 
EH-K 
-K 
Duration of Clock Low Pulse 


2. The internal address strobe is always active. 
3. RCLK =- tXH and tXL. 
4. Charge and discharge time is determined by VOL, VOH and the external loading. 
5. All timings are referenced to valid O and valid 1. 
(see AC TEST POINTS). 
6. RCLK is internally derived from the internal -BAUDOUT signal. 
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Conditions 


100 pF Load 


100 pF Load, Note 4 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


Nme2 


External Clock 


External Clock 
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AC CHARACTERISTICS (Cont.) TA= orc to +1o°c, vcc= 5 v ;l:5°/> (Notes 1, s) 


VL1 6C452 


Symbol 
Parameter 
Conditions 


age 


Transmitter 


tHR 
Delayfrom Rising Edge of -IOW 


_ _ 
, 
CLK 
tlRS 
Delay from Initial INTR Reset to Transmit Start - 


CLK 


Delay from initial Write to Interrupt 
Cycies 


Delay from Stop to Interrupt (THRE) 
C CILK 
yc es 


to Reset Interrupt (THRE) 


-H 


Receiver 


tSlNT 
Delay from Stop to Set Interrupt 
- 
Q52: 
°°"“"'°"‘ 
I1 
‘Film 
no RBR/RDLSR 
II 
s 


knowledge) 
ps 


Modem Control 


Delay from -IOW 
‘M90 
(we MCR) to Output 


tSlM 
Delay to Set Interrupt from MODEM Input 


mm 
Delay to Reset interrupt from 
-IOR (RS MSR) 


to Reset lnterrut 


tDT 
Data "lime 


tSB 
trobe Time 


tAD 


tAKD 
cknowledge Delay (Busy End to Acknowledge) 


tAK 


tBSY 


tBSD 


Parallel Port 
ER 
iii 
ii 
it 
ii 
ii 


Acknowledge Delay (Busy Start to Ac 


Acknowledge Duration Time 


Busy Duration Time 


Busy Delay Time 


Notes: 
1. All timing specifications apply to pins on both serial channels (e.g. RI refers to both RIO and RI1). 
2. The internal address strobe is always active. 
3. RCLK - tXH and tXL. 
4. Charge and discharge time is determined by VOL, VOH and the external loading. 
5. All timings are referenced to valid 0 and valid 1 (see AC TEST POINTS). 
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100 pF Load 


Note 3 


Note 3 


Note 3 


100 pF Load 


100 pF Load 


100 pF Load 


100 pF Load 


Note 3 


100 pF Load 


Defined by Printer 


Defined by Printer 


Defined by Printer 


Defined by Printer 


Defined by Printer 
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WRITE CYCLE TIMING 


A2 A1 A0 


-cs 


tWA 


VALID 


tWCS 


IOSW i——D 
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tAW 
WC 
4- tDOW 


-IOW 
ACTIVE 
ACTIVE 
4 
OR 


-IOR 
$ACTIVE 


iosl 
4-ioH>| 


DATA 


READ CYCLE TIMING 


A2 A1 A0 


-cs 


-IOR 


-IOW 


DATA 
D0-D7 


VALID 


VALID 


S" tRCS 


ICSR -—-iii 


tAR 
RC 
4— tDIW 


ACTIVE 


I000 4—-> 
—> 
'4- 


VALID 
DATA 
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ACTIVE 


NYACTIVE 
4%» 
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RECEIVER TIMING 


SIN 
(RECEIVER 
START 
DATA BITS is-s) 
STOP 
INPUT 
DATA) 


SAMPLE 
CLK 
| 
| 
| 


INTERRUPT 
(DATA READY OR 
RCVR ERR) 


-IOR 


TRANSMITTER TIMING 


START 
SERIAL 
DATA (s-e) 
. 
_ 
OUT (SOUT) 
STOP (1 2) 
PARITY 


ISINT 
§-—- 


ACTIVE 


START 


VL16C452 
S 


IRINT 


“Rs 
—> 
<— tSTI 
INTERRUPT 
(THRE) 
tHR1 
-Iow 
(we THR) 
tS| -> 
__> “R 


-IOR 
(ac IIR) 


MODEM TIMING 


-IOW 
(WR MCR) 
T-————-—_—\J<— 


tMDO 
tMDO --> 
<- 
-RTS. -DTR 


-CTS,-DSA,-RLSD 


-INTERRUPT 
H 


-IOR 
(RD MSR) 


—Rl 
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-5 tDT 4i> 
IDT 


STROBE 


-ACK 


—>ISB4— 


4- tAD —-—-—-> 4—tAK—> 


BUSY 
tAKD <- 


IBSD -5 <—tBSY 


AC TESTING INPUT/OUTPUT WAVEFORMS 


EXTERNAL CLOCK INPUT 
AC TEST POINTS 


L 


TEST CIRCUIT 



4-tXL-P 


4-D 
tXH 


2.0 V 
2.0 V 
C K 


0.8 V 0.8 V 


2.54 -V 


r— 
Output Under Test 


6809 


82 pF‘ 


Includes Scope and Jig I 
Capacitance 
-_-L- 


1 00 
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ABSOLUTE MAXIMUM RATINGS 


Ambient Operating 
Stresses above those listed may cause 
Temperature 
-10°C to +70°C 
permanent damage to the device. 


Storage 


those indicated in this data sheet is not 
implied. Exposure to absolute maximum 
rating conditions for extended periods 
Temperature _65..Cto+150..C 
These.are stress ratings only, functional 
o 
_ 
__ 
may affect device reliability. 
operation of this device at these or any 
Supply Voltage I° 
other conditions above 
Ground Potential -0.5 V to VCC + 0.3 V 


Applied Output 
Voltage 
-0.5 V to VCC + 0.3 V 


Applied Input 
Voltage 
-0.5 V to + 7.0V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = 0 to +1000, vcc = s v .1; 5% 


Parameter 
S mbol 


VILX 


VIHX 


VIL 


VIH 


VOL 


VOH 


ICC 


IIL 


ICL 


IOZ 


UIO1 


Conditions 


Clock 


Clock 


Input 


In ut Low Voltae 


Input High 


Low 


Voltage 
VCC 


Voltage 


Input High Voltage 
VCC 


Output Low Voltage 
V 


Clock Leakage 
:1: 


3-State Leakage 
|.IA 


-A-5 @@ 


IOL - 4.0 mA on DBO - DB7 
IOL - 12 mA on PDO - PD7 
IOL - 10 mA on -N IT, -AFD, -STB, 
and —SLlN (see Note 1) 
IOL - 2.0 mA on all other outputs 


IOH - -0.4 mA on DBO - DB7 
IOH - -2.0 mA on PDO - PD7 
IOH -. -0.2 mA on -INIT, -AFD, -STB, 
and -SLIN 
IOH - -0.2 mA on all other outputs 


VCC - 5.25 V, No loads on SlN0,1; 
—DSRO,1;—RLSDO,1;-CTSO,1.—Rl0, 
—Rl1 - 2.0 V. Other inputs - 0.8 V. Baud 
rate generator - 4 MHz. Baud rate - 56K 


VCC - 5.25 V. GND -. 0 V. 
All other pins floating. 


VIN - o v, 5.25 v 


VCC -. 5.25 V, GND - 0 V. 
VOUT - 0 V, 5.25 V 
1) Chip deselected 
2) Chip and write mode selected 


Output High Voltage 


Power Supply Current 


Input Leakage 
:1: ii 


VIL(RES) 
Reset Schmitt VIL 


VlH(RES) 
Reset Schmitt VIH 
HE 
Note 1. —lNIT, -AFD, -STB, and —SLlN are open collector output pins that each have an internal pull-up resistor (2.5 kn - 3.5 kn) 
to VCC. This will generate a maximum of 2.0 mA of internal IOL. In addition to this internal current, each pin will sink at least 10 
mA, while maintaining the VOL specification of 0.4 V Max. 
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ASYNCHRONOUS COMMUNICATIONS ELEMENT WITH FIFOS 
FEATU RES 


- Fully compatible with VL16C450 ACE 


- 16 byte FIFO reduces CPU interrupts 


- Full double buffering 


- Modem control signals include -CTS, 
—RTS, -DSR, -DTR, -RI and —DCD 


- Programmable serial characteristics: 
— 5-, 6-, 7- or 8-bit characters 


— Even-, odd-, or no-parity bit genera- 
tion and detection 
- 1-, 1 1/2- or 2-stop bit generation 
- Baud rate generation (dc to 56K 
baud) 


- Independent control of transmit, 
receive, line status, data set interrupts, 
FlFOs 


- Full status reporting capabilities 


- Three-state, 'lTL drive capabilities for 
bidirectional data bus and control bus 


DESCRIPTIONS 
The VL16C550 is an asynchronous 
communications element (ACE) that is 
functionally equivalent to the 
VL16C450, and additionally incorpo- 
rates a 16 byte FIFO. The FlFOs are 
available on both the transmitter and 
receiver, and can be activated by 
placing the device in the FIFO mode. 
After a reset, the registers of the 
VL16C550 are identical to those of the 
VL16C450. 


Improved VL16C550 specifications 
provide compatibility with most newer 
state-of-the-art CPUs. The VL16C550 
serves as a serial data input/output 
interface in microcomputer systems. It 
performs serial-to-parallel conversion 
on data characters received from 
peripheral devices or modems, and 
parallel-to-serial conversion on data 


characters transmitted by the CPU. In 
the FIFO Mode, FlFOs are enabled 
permitting 16 bytes to be stored in both 
transmit and receive mode. The FiFOs 
also provide three bits per byte of error 
data in the receiver FIFO. The com- 
plete status of the ACE can be read at 
any time during functional operation by 
the CPU. The information obtained 
includes the type and condition of the 
transfer operations being performed, 
and error conditions involving parity, 
overrun, framing, or break interrupt. 


A programmable baud rate generator is 
included that can divide the timing 
reference clock input by a divisor 
between 1 and (2‘6-1). 


The VL16C550 ACE with FlFOs is 
available in both plastic and ceramic 
DIP as well as a PLCC. 


PIN DIAGRAMS 
VI-159550 


VL16C550 


D0 I 
1 
40 I VCC 
D1 I 2 
39 
-RI 
D2 I 3 
38 I —DCD 
D3 I 4 
37 I -DSR 
D4 I 5 
36 I -CTS 
D5 I 6 
35 I MR 
D6 I 7 
34 I -OUT1 
D7 I 8 
33 I -DTR 
RCLK I 9 
32 I —RTS 
SIN I 10 
31 I -OUT2 
SOUT I 
CSO I 
CS1 I 
-CS2 I 
-BAUDOUT I 
XTAL1 I 
XTAL2 I 
-DOSTR I 
DOSTR I 
VSS I 


I INTRPT 
I RXRDY 
I A0 
I A1 
I A2 
I -ADS 
I TXRDY 
I DDIS 
I DISTR 
I -DISTR 


D3 
D1 
N.C. 


D57 
oee 
Q 
e 
D7 
II 
RCLK I 
10 


SIN I 
11 
N.C. I 
12 
SOUT I 
13 
CSO I 
14 


CS1 I 
15 
-CS2 I 
16 
-BAUDOUT I 
17 


—DCD 


—DSR 
I-—CTS 


41 40 
39 I 
MR 
38 I 
—OUT1 
37 II -DTR 
36 I 
—RTS 


35 I 
-OUT2 
34 I 
N.C. 
33 I 
INTRPT 
32 I 
RXRDY 


31 I 
A0 
30 I 
A1 
29 I 
A2 


e.-‘,2 oiI— ..-3 <.oI— 
N_8 _.-_ tI§8I—§ ,I 
I 
- 


1819202122232-125262728 
I I I I I I I I I I I 
XTAL1 | 
vss | 
DDISI -ADS 


NC 
XTAL2 


-DOSTR 
—DISTR 
TXRDY 


-DOSTR 
DISTR 


ORDER INFORMATION 


VL16C550-PC 
Plastic DIP 
VL16C550-CC 
Ceramic DIP 


External 
Part 
Clock 
Number 
Frequency 
Package 


VL16C550-QC 
Plastic Leaded Chip Carrier (PLCC) 


Note: Operating temperature range is 0 C to + 70 C. 
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FEATURES 
- Built-in data separator 


- Built-in write precompensation 


- Single and double density 


- Motor control 


- 128, 256, 512, or 1024 sector lengths 
' TI'L compatible 


- 8-bit bidirectional data bus 


- Fast step rates 


- 28-pin DIP 


- Single 5 V power supply 


DESCRIPTION 
The VL1772-02 is an MOS/LSI device 
that performs the functions of a oppy 
disk controller/formatter. It replaces the 


VL1772-02 
FLOPPY DISK CONTROLLER/FORMATTER 


older 1770-type device. The drive side 
of the interface needs no additional logic 
except for buffers/receivers. Designed 
for single- or double-density operation, 
the device contains a programmable 
Motor On signal. 


The VL1772-02 is implemented in 
NMOS silicon-gate technology and is 
available in a 28-pin dual in-line 
package. lt is a low-cost version of the 
WD179X Floppy Disk Controllerl 
Formatter and is compatible with generic 
179X types. lt also has a built-in digital 
data separator and write precompensa- 
tion circuits. A single read (RD) line (pin 
19) is the only input required to recover 
serial FM or MFM data from the disk 
drive. The device has been specifically 
designed for control of floppy disk drives 


with data rates of 125K bps (single 
density) and 250K bps (double density). 
ln addition, it can write a precompensa- 
tion that is125 ns from nominal, and can 
be enabled at any point through simple 
software commands. Another program- 
mable feature, Motor On, has been 
incorporated to automatically enable 
the spindle motor prior to operating a 
selected drive. The VL1772-02 offers 
stepping rates of 2, 3, 6, and 12 ms. 


The processor interface consists of an 
8-bit bidirectional bus for transfer of the 
status information, data, and com- 
mands. All host communication with 
the drive occurs through these data 
lines. They are capable of driving one 
standard Tl'L load orthree LS loads. 


PIN DIAGRAM 


VL1772-02 


E; 
1 
2a I mrno 
R/Ti 
2 
27 I DRQ 


A0 
3 
26 I EDEN 


A1 
4 
25 I V/i5'r=" 
DALO 
5 
24 I IF 


DAL1 
6 
23 I T356 
DAL2 
7 
22 I wo 
DAL3 
e 
21 I we 
DAL4 
9 
2o I MO 
DAL5 I10 
19 I iii 
DAL6 
11 
1s I CLK 
DAL7 
12 
17 I DIRC 
Vii 
1a 
1e I STEP 


GND I 14 
15 I VCC 


BLOCK DIAGRAM 
DALO-B 


B 


DATA OUT 
BUFFERS 


IQ‘? 
EII 
Iii!-‘;|l'II-all 


— 
DATA 
MM 
0 
sscron 
CK 
sums 
nscrsren 
REGISTER 
REGISTER 
REGISTER 
REGISTER 


||=r- 


DATA 
su 
EGIS 
’ 
| 
INTERNAL 
BUS 
AM osrecron 
DATA 
SEP 
ATOR 
WRI 
PREC 
cnc LOGIC 
one 
we 
|NTRQ 
v ; '.' 
ma 
‘—'r:r* 
5? 
COMPUTER 
PLA 
DISK 
moo 
=' 
INTERFACE 
°°NTF'°L 
CONTROL 
°°"m°L 
INTERFACE 
sree 
M 
CONTROL 
(240 X 19) 
CONTROL 
omc 
uo 
CLK(8MHl) 


DDEN 


ORDER INFORMATION 
Part 
Number 
Package 


VL1772-02PC 
Plastic DIP 
VL1772-02QC 
Plastic Leaded Chip Carrier (PLCC) 
VL1772-0200 
Ceramic DIP 


Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL 
DESCRIPTIONS 
Slgnal 
Pin 
Slgnal 
Name 
Number 
Descrlptlon 


CS 
1 
Chip Select - A logic low on this input selects the chip and enables host communication 
with the device. 


R/‘W 
2 
ReadNVrite - A logic high on this input controls the placement of data on the D0-D7 lines 
from a selected register, while a logic low causes a write operation to a selected register. 


A0, A1 
3,4 
Address 0, 1 - These two inputs select a register to read or write data: 


DALO - DAL7 
5 - 12 


r?! 


GND 


VCC 


STEP 


DIRC 


CLK 


W 


MO 


WG 


WD 


TR00 


IP 


WPRT 


DDEN 


DRQ 


INTRO 


-oooo 


CD 
R 
= 1 
nu 
Status Reister 
Command Reister 
nu 
Track Re ister 
Track Re ister 
—m 
Sector Reister 
Sector Reister 
I -_ -. I ~ i - 


Data Access Lines 0 through 7 - Eight-bit t_>_idirectionil_bus used for transfer of data, 
control, or status. This bus is enabled by CS and R/W. Each line drives one Tl'L load. 


Master Reset - A logic low pulse on this line resets the device and initializes the status 
register (internal pull-up). 


Ground - Ground 


Power Supply - +5 V :t5% power supply input. 


Step - The Step output contains a pulse for each step of the drive's R/W head. This is a 
pulse to the disk drive. 


Direction - The Direction output is high when stepping in towards the center cl the 
diskette, and low when stepping out. 


Clock - This input requires a free-running 50% duty cycle clock (for internal timing) at 8 


MHZ 11.10/o. 
. I 
\ . 
Read Data - This active-low input is the raw data line containing both clock and data 
pulses from the drive. 


Motor On - Active high output used to enable the spindle motor prior to read, write, or 
stepping operations. 


Write Gate - This output is made valid prior to writing on the diskette. 


Write Data - FM or MFM clock and data pulses are placed on this line to be written on 
the diskette. 


Track 00 - This active-low input informs the VL1772-02 that the drive's R/W heads are 
positioned over Track zero (internal pull-up). 


Index Pulse - This active-low input informs the VL1772-02 when the physical index hole 
has been encountered on the diskette (internal pull-up). 


Write Protect - This input is sampled whenever a Write Command is received. A logic 
low on this line prevents any Write Command from executing (internal pull-up). 


Double Density Enable - This input pin selects either single (FM) or double (MFM) 
density. When DDEN = 0, double density is selected (internal pull-up). 


Data Request - This active-high output indicates that the Data Register is tull (on a 
Read) or empty (on a Write) operation. 


Interrupt Request - This active-high output is set at the completion of any command or a 
read of the Status Register. 
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ARCHITECTURE 
TheVL1772-02 Floppy Disk Controllerl 
Formatter block diagram is illustrated on 
the front page. The primary sections 
include the parallel processor interface 
and the floppy disk interface. 


Data Shift Register - This 8-bit register 
assembles §gr_ial data from the Read 
Data input (RD) during read operations 
and transfers serial data to the Write 
Data output during write operations. 


Data Register - This 8-bit register is 
used as a holding register during disk 
read and write operations. In disk read 
operations, the assembled data byte is 
transferred in parallel to the Data 
Register from the Data Shift Register. In 
disk write operations, information is 
transferred in parallelfrom the Data 
Register to the Data Shift Register. 


When executing the Seek command, the 
Data Register holds the address of the 
desired track position. This register is 
loaded from the Data Access Lines 
(DAL) and gated onto the DAL under 
processor control. 


Track Register - This 8-bit register holds 
the track number of the current readl 
write head position. It is incremented by 
one every time the head is stepped in 
and decremented by one every time the 
head is stepped out (towards Track 00). 
The contents of the register are com- 


pared with the recorded track number in 
the ID field during disk read, write, and 
verify operations. The Track Register 
can be loaded from or transferred to the 
DAL. This register should not be loaded 
when the device is busy. 


Sector Register (SR) - This 8-bit register 
holds the address of the desired sector 
position. The contents of the register 
are compared with the recorded sector 
number in the ID field during disk read 
or write operations. The Sector Register 
contents can be loaded from or trans- 
ferred to the DAL. This register should 
not be loaded when the device is busy. 


Command Register (CR) - This 8-bit 
register holds the command presently 
being executed. This register should not 
be loaded when the device is busy, 
unless the new command is a forced 
interrupt. The Command Register can 
be loaded from the DAL but not read 
onto the DAL. 


Status Register (STR) - This 8-bit 
register holds device status information. 
The meaning of the status bits is a 
function of the type of command 
previously executed. This register can 
be read onto the DAL but not loaded 
from the DAL. 


CRC Logic - This logic is used to check 
or to generate the 16-bit cyclic redun- 


dancy check (CRC). The polynomial is: 


G(x) = x16+ x12 + x5+1 


The CRC includes all information 
starting with the address mark and up to 
the CRC characters. The CRC register 
is preset to ones prior to data being 
shifted through the circuit. 


Arithmetic/Logic Unit (ALU) - The ALU is 
a serial comparator, incrementer, and 
decrementer and is used for register 
modification and comparisons with the 
disk-recorded ID field. 


‘liming and Control - All computer and 
floppy disk interface controls are 
generated through this logic. The 
internal device timing is generated from 
an external crystal clock. The VL1772- 
02 has two different modes of operation 
according to the state of DDEN: When 
DDEN - 0, double density (MFM) is 
enabled. When DDEN - 1, single 
density is enabled. 


Address Mark Detector - The AM 
detector detects ID, data, and index 
address marks during read and write 
operations. 


Data Separator - A digital data separa- 
tor, consisting of a ring shift register and 
data window detection logic, provides 
read data and a recovery clock to the 
AM detector. 


FIGURE 1. SYSTEM BLOCK DIAGRAM 


HOST 


WG 
‘ 
WD 
RD 
anE 


INTERFACE 
Vl-1 772-02 
-I: 


TI5 


TR00 
WFTIT 


MO 


DIRC 


STEP 
DRO 


5 V 
cup vcc 


__ 
sv 
_'I__ o'_'oEN 
" 


5 1/4 INCH 


FLOPPY 


DRIVE 
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DESCRIPTION 
PROCESSOR INTERFACE 
The interface to the processor is 
accomplished through the eight data 
access lines (DALs) and associated 
control signals. The DALs are used to 
transfer data, status, and control words 
out of, or into the VL1772-02. The DALs 
are three-state buffers that are enabled 
as output c_i_rj_vers when Chip Select I) 
= 0 and R/W = 1 are give, or act as 
input receivers when CS and R/W = 0 
are active. 


When transfer of data with the Floppy 
Disk Controller is required by the host 
processor, the device address is 
decoded and (T is made low. The 
address bits A1 and A0, combined with 
the signal RIW during a read or write 
operation, are interpreted as selecting 
the following registers: 


sector is reached. 


On disk write operations, the Data 
Request is activated when the Data 
Register transfers its contents to the 
Data Shift Register, and requires a new 
data byte. It is reset when the Data 
Register is loaded with new data by the 
processor. if new data is not loaded at 
the time the next serial byte is required 
by the floppy disk, a byte of zeros is 
written on the diskette and the Lost Data 
bit is set in the Status Register. 


At the completion of every command an 
INTRO is generated; it is reset by either 
reading the status register or by loading 
the command register with a new 
command. In addition, INTRO is 
generated if a Force interrupt command 
condition is met. 


I f____’1 
1 
.1’ 
A1 - A0 
READ (R/W51) 
WRITE(R/W = 0) 


-l—I~QO 


0 
Status Register 
Command Register 
1 
Track Register 
Track Register 
0 Sector Register 
Sector Register 
1 
Data Register 
Data Register 
___ 


After any register is written to, the same 
register cannot be read from until 16 p.s 
in MFM or 32 us in FM have elapsed. 


During direct memory access (DMA) 
types of data transfers between the 
Data Register of the VL1772-02 and the 
processor, the Data Request (DRO) 
output is used in data transfer control. 
This signal also appears as status bit 1 
during read and write operations. 


On disk read operations, the Data 
Request is activated (set high) when an 
assembled serial input byte is trans- 
ferred in parallel to the Data Register. 
This bit is cleared when the Data 
Register is read by the processor. If the 
Data Register is read after one or more 
characters are lost, by having new data 
transferred into the register prior to 
processor readout, the Lost Data bit is 
set in the Status Register. The read 
operation continues until the end of 


The VL1772-02 has two modes of 
operation, according to the state of 
DDEN . When DDEN = 1, single density 
is selected. In either case, the CLK 
input is at 8 MHz. 


GENERAL DISK READ OPERATIONS 
Sector lengths of 128, 256, 512, or 1024 
bytes are obtainable in either FM or 
MFM formats. For FM, DDEN should be 
[:_>_la§__e_dto logical "1". For MFM formats, 
---PAUIERN 
I ' 
I 
DDEN should be placed to a logical "0". 


Sector lengths are determined at format 
time by the fourth byte in the "lD" field. 


VL1 772-O2 


There are from 0 to 244 sectors per 
track for the VL1772-02, and from 0 to 
244 tracks. 


GENERAL DISK WRITE OPERATION 
When writing is to take place on the 
disk the Write Gate (WG) output is 
activated, allowing current to flow into 
the read/write head. As a precaution to 
erroneous writing, the first data byte 
must be loaded into the Data Register 
in response to a Data Request from the 
device before the Write Gate signal can 
be activated. 


Writing is inhibited when the Write 
Protect input is a logic low, in which 
case any Write command is immedi- 
ately terminated, an interrupt is gener- 
ated, and the Write Protect status bit is 
set. 


For write operations, the VL1772-02 
provides Write Gate to enable a write 
condition, and Write Data which 
consists of a series of active-high 
pulses. These pulses contain both 
clock and data information in FM and 
MFM. Write Data provides the unique 
missing clock patterns for recording 
address marks. 


The Precompensation Enable bit in 
Write commands allow automatic write 
precompensation to take place. The 
outgoing write data stream is delayed or 
advanced from nominal by 187ns 
according to the following table: 


MFM 
_fM 
Early 
NIA 
Late 
NIA 
Early 
NIA 
Late 
NIA 
-5 
Q 
Q 
Q 


SECTOR LENGTH TABLE 
sscron LENGTH 
uumeen or BY-T-ES“ 


i 
I 
pi 


OXX 
CO4 
Q..i._|. 


—-»-so 


i.__._._.l 
— Next Bit to be sent 
Current Bit sending 
_[. 


FIELD (HEX) 
IN secron (DECIMAL) 
P'°vi°"$ Bits 88"‘ 
00 
128 
01 
256 
02 
512 


. °.3-_. 
_!9?4___ 
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Precompensation is typically enabled 
on the innermost tracks where bit shifts 
usually occur and bit density is at its 
maximum. 
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COMMANDS 
The VL1772-02 accepts eleven com- 
mands. Command words should only be 
loaded in the Command Register when 
the Busy Status Bit is off (Status Bit 0). 
The one exception is the Force Interrupt 
command. 
Whenever a command is 
being executed, the Busy Status Bit is 
set. When a command is completed, an 
interrupt is generated and the Busy 
status bit is reset. The Status Register 
indicates whether the completed 
command encountered an error or was 
fault-free. For ease of discussion, 
commands are divided into four types 
and are summarized in 
Table 1. 


The Type I Commands (see Figure 2) 
include the Restore, Seek, Step, Step-in, 
and Step-out commands. Each of the 
Type I Commands contains a rate field 
(r0, r1), which determines the stepping 
motor rate. 


A 4 us (MFM) or 8 us (FM) pulse is 
provided as an output to the drive. For 
every step pulse issued, the drive moves 
one track location in a direction deter- 


mined by the direction output. 
The chip 
will step the drive in the same direction it 
last stepped unless the command 
changes the direction. 


The Direction signal is active-high when 
stepping in and low when stepping out. 
The Direction signal is valid 24 us before 
the first stepping pulse is generated. 


After the last directional step, an 
additional 30 ms of head settling time 
takes place if the Verify flag is set in 
Type I commands. There is also a 30 
ms head settling time if the E flag is set 
in any Type ll or lll command. 
When a Seek, Step, or Restore com- 
mand is executed, an optional verifica- 
tion of read/write head position can be 
performed by setting bit 2 (V = 1) in the 
command word to logic 1. The verifica- 
tion operation begins at the end of the 
30 ms settling time after the head is 
loaded against the media. The track 
number from the first encountered ID 
Field is compared against the contents 
of the Track Register. if the track 
numbers compare and the ID Field cyclic 


TABLE 1. COMMAND SUMMARY 
inj 
1 
T 
BITS 


N 
O) 
O‘! 
b 
Q 
IO 


redundancy check (CRC) is correct, the 
verify operation is complete and an 
INTRO is generated with no errors. If 
there is a match but not a valid CRC, the 
CRC Error Status Bit is set (Status Bit 
3), and the next encountered ID field is 
read from the disk for the verification 
operation. 


The VL1772-02 must find an ID field 
with correct track number and correct 
CRC within five revolutions of the media, 
otherwise, the seek error is set and an 
INTRO is generated. If V =- 0, no 
verification is performed. 


All commands, except the Force 
Interrupt command, may be pro- 
grammed via the h Fiag to delay for 
spindle motor start up time. if the h Flag 
is not set and the Motor On line is low 
when a command is received, the 
VL1772-02 will force Motor On to a logic 


1 and waits six revolutions before 
executing the command. At 300 RPM, 
this guarantees a one-second spindle 
start-up time. If, after finishing the 


TYPE || a ||| commmps 
0 
I 


i_ _____ 


--ooooo 
O0-#-#000 
-I-o-I-0-00 
33 
cc 
1:-+0 
:r:r:r:r:r:r:r 
mm<<<<< 


Seek 
Step 
r1 
Step-in 
r1 


i 
I 
i 
I 
I 
Step-out 
II 
Read Sector 
II Write Sector 
III 
Read 
Address 
1 
1 
0 
0 
h 
E 
III 
ReadTrack 
1 
1 
1 
0 
h 
E 
III WrlteTrack 
1 
1 
1 
1 
h 
E 
IV Force 
Interrupt 
1 
1 
0 
1 
I3 
I2 
I, 


Restore 
r1 
'1 
To 


I’ 
0 
P30 
00 
T 
00 
0 


3 = Multiple“ Sector Flag (Bit 4) 


I33 


ro 
2 
2 


To 
= 0, Single Sector 
= 1, Multiple Sector 


'0 
= Motor On Flag (Bit 3)), 
_ 


II 
3’ 
= 0, Enable Spin Up Sequence 
= 1, Disable Spin Up Sequence 


ao = Data Address Mark (Bit 0) 


"‘<§’<§’ 


= Write Normal Data Mark 
= 1, Write Deleted Data Mark 
= 15ms Settling Delay (Bit 2) 
I 
___ 


ITI 
'0 
= 0, No Delay 
I 
—__ 
'1”. 
FLAG SUMMARY ' 
" 


ITYFPE | coivuviauos 
I 
I 
' 
F’ 
poo-I’* 
__ 
h 
Motor On Flag (Bit 3) 


3'3" 
= 0, Enable Spin-up Sequence 
= 1, Disable Spin-up Sequence 
_ 
--= 
rify Flag (Bit 2) 


<< 
Va 
I 
A 
I 
I 
= 0, No Verify 
V = 1, Verify on Destination Track 


r1, ro = Stepping Rate (Bits 1,0) 


J 
7 
I 
_ 
To 
mi 
j 
W 
1772-O2 


-5-LQQ 
_.|>Q_LQ 


6 ms 
12 ms 
2 ms 
3 ms 
u = Update Flag (Blt 4) 
u = 0, No Update 
u = 1, Update Track Register 


VH1 
= 1, Add 15ms Delay 
= Write Precompensation (Blt 1) 


UU 
= 0,Enable Write Precomp 
,= 1,Disable Write Precomp 


TYPE IV COMMANDS 


I3-lo Interrupt Condition (Bits 3-0) 
g 
g __ 


lo = 1, Not Used 
I, = 1, Not Used 


I2 = 1, Interrupt on Index Pulse 


I3 = 1, Immediate Interrupt 


I3-lo = 0, Terminate without interrupt 
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command, the device remains idle for 
RESTORE (SEEK TRACK 0) 
ten revolutions, the Motor On line goes 
Upon receipt of this command, the Track 
back to a logic 0. If a command is 
00 (TR00) input is sampled. If TR00 is 
issued while Motor On is high, the 
active-low indicating the read/write head 
command executes immediately, defeat- 
is positioned over Track 00, the Track 
ing the six-revolution start up. This 
Register is loaded with zeros and an 
feature allows consecutive read or write 
interrupt is generated. If TR00 is not 
commands without waiting for each 
active-low, stepping pulses (pin 16) at a 
motor start-up; the VL1772-02 assumes 
rate specified bygr1, r0 field are 
the spindle motor is up to speed. 
issued until the TR00 input is activated. 


At this time, the Track Register is loaded 
with zggand an interrupt is generated. 
If the TR00 input does not go active-low 
after 255 stepping pulses, the VL1772- 
02 terminates operation, interrupts, and 
sets the Seek Error Status Bit, providing 
the V flag is set. A verification operation 
also takes place if the V flag is set. The 
h bit allows the Motor On option at the 
start of command. 


FIGURE 2. TYPE I COMMAND FLOWCHART 


ENTER 


HA 
A TYPE I 
COMMAND BEEN 
RECEIVED 


YES 


SET BUSY RESET CRC 
SEEK ERROR DRO INTROltl 


SET MO 
WAIT 6 INDEX PULSES 


IS 
COMMAND 
YE5 
A 
STEPJN 


~o 


IS 
COMMAND 
YES 
A 
srse-our 


NO 


IS 
COMMAND 
YES 
A 
STEP 


~o 


IS 
YES 
COMMAND 
A 
SEEK 


NO 


NO 


NO 


SET 
DIRECTION 


RESET 
DIRECTION 


YES 


DR TO DSR. 


DOES 
YES 
TR = DSR 


NO 


YES 


u 
RESET DIRECTION 
SET DIRECTION 


IS 
I 
DIRECTION 
YES 
= 
1 


IS 
HEAD AT 
YES 
TRACKDAND 
0101"; 
DIRECTION 


-1TOTR 


=0 


ISSUE 
ONE STEP PULSE 


RESTORE 
DELAY ACCORDING 
FFH TO TR 
TO R1.R0 FIELD 


OTO DR 
IS 
NO 
NO 
COMMAND 
A step, srse-m 
0 
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FIGURE 2. TYPE I COMMAND FLOWCHART (Cont.) 
FIGURE 3. TYPE II COMMAND FLOWCHART 


ENTER 


IS 
TYPE ll 
NQ 
COMMAND 
RECEIVED 
VERIFY 
SEQUENCE 
vss 


SET eusv asser one LOST 
N0 
DATA, RECORD NOT FOUND, a 
STATUS BITS 5 a 5 INTRO 


YES 
INTRO RESET eusv 
NO 


HAVE 
6 INDEX 
YES 
HOLES 
PASSED 
YES 


NO 
INTRO, RESET BUSY 
SET SEEK ERROR 


,0 A',f,’°‘§EEN 
6 moex PULSES 


DETECTED 


SET MO 
WAIT 


YES 


ooss 
NO 
TR = TRAC 
ADDRESS OF I0 
FIELD 


YES 


HAS 
aoms 
IS 
SSE 
THERE A 
N0 
RESET 
EXPIRED 
CRC ERROR 
cnc 
ERROR 


IS 
is 
INTRO 
YES 
WRITE 
YES 
CQMMANQ 
RESET BUSY 
PROTECT 
A 
ON 
WRITE 


NO 


INTRO, RESET BUSY 
‘ 
SET WRITE PROTECT 
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SEEK 
This command assumes that the Track 
Register contains the track number of 
the current position of the read/write 
head and the Data Register contains the 
desired track number. The VL1772-02 
will update the Track Register and issue 
stepping pulses in the appropriate 
direction until the contents of the Track 
Register are equal to the contents of the 
Data Register (the desired track 
location). A verification operation takes 
place if the V flag is on. The h bit allows 
the Motor On option at the start of the 
command. An interrupt is generated at 
the completion of the command. ( Note: 
When using multiple drives, the track 
register must be updated for the drive 
selected before seeks are issued.) 


STEP 
Upon receipt of this command, the 
VL1772-02 issues one stepping pulse to 
the disk drive. The stepping motor 
direction is the same as in the previous 
step command. After a delay deter- 
mined by the r1, r0 field, a verification 
takes place if the V flag is on. If the U 
flag is on, the Track Register is updated. 
The h bit allows the Motor On option at 
the start of the command. An interrupt 
is generated at the completion of the 
command. 


STEP-IN 
Upon receipt of this command, the 
VL1772-02 issues one stepping pulse in 
the direction towards track 76. If the U 
flag is on, the Track Register is incre- 
mented by one. After a delay is 
determined by the r1, r0 field, a verifica- 
tion takes place if the V flag is on. The h 
bit allows the Motor On option at the 
start of the command. An interrupt is 
generated at the completion of the 
command. 


STEP-OUT 
Upon receipt of this command, the 
VL1772-02 issues one stepping pulse in 
the direction towards track 0. If the U 
flag is on, the Track Register is decre- 
mented by one. After a delay deter- 
mined by the r1, r0 field, a verification 
takes place if the V flag is on. The h bit 
allows the Motor On option at the start of 
the command. An interrupt is generated 
at the completion of the command. 


TYPE ll COMMANDS 
The Type ll Commands (see Figure 3) 


are the Read Sector and Write Sector 
commands. Priorto loading the Type ll 
Command into the Command Register, 
the computer must load the Sector 
Register with the desired sector number. 
Upon receipt of the Type ll command, 
the busy status bit is set. If the E flag = 
1, the command executes after a 15 ms 
delay. 


When an ID field is located on the disk, 
the VL1772-02 compares the track 
number on the ID field with the Track 
Register. If there is not a match, the 
next encountered ID field is read and a 
comparison is again made. If there was 
a match, the sector number of the ID 
field is compared with the Sector 
Register. If there is not a sector match, 
the next encountered ID field is read off 
the disk and comparisons again made. 
If the ID field CRC is correct, the data 
field is then located and is either written 
into or read from depending upon the 
command. The VL1772-02 must find an 
ID field with a track number, sector 
number, and CRC within four revolutions 
of the disk; otherwise, the Record Not 
Found Status Bit is set (Status Bit 4) and 
the command is terminated with an 
interrupt (INTRO). 


Each of the Type ll Commands contains 
an m flag that determines if multiple 
records (sectors) are to be read or 
written, depending upon the command. 
if m = 0, a single sector is read or written 
and an interrupt is generated at the 
completion of the command. If m == 1, 
multiple records are read or written with 
the sector register internally updated so 
that an address verification can occur on 
the next record. The VL1772-02 
continues to read or write multiple 
records and update the sector register in 
numerical ascending sequence until the 
sector register exceeds the number of 
sectors on the track or until the Force 
Interrupt command is loaded into the 
Command Register, which terminates 
the command and generates an 
interrupt. 


For example: if the VL1772-02 is 
instructed to read sector 27 and there 
are only 26 sectors on the track, the 
sector register exceeds the number 
available. The VL1772-02 will search 
for five disk revolutions, interrupt out, 
reset busy, and set the Record Not 
Found Status Bit. 


READ SECTOR 
Upon receipt of the Read Sector 
command, the Busy status bit is set, and 
when an ID field is encountered that has 
the correct track number, correct sector 
number, and correct CRC, the data field 
is presented to the computer. The data 
address mark (DAM) of the data field 
must be found within 30 bytes in single 
density and 43 bytes in double density 
of the last ID field CRC byte; if not, the 
ID field is searched for and verified 
again followed by the data address mark 
search. If, after five revolutions the 
DAM cannot be found, the Record Not 
Found StatusBit is set and the operation 
is terminated. When the first character 
or byte of the data field has been shifted 
through the DSR, it is transferred to the 
DR, and DRO is generated. If the 
computer has not read the previous 
contents of the DR before a new 
character is transferred, that character is 
lost and the Lost Data Status bit is set. 
This sequence continues until the 
complete data field has been input to the 
computer. if there is a CRC error at the 
end of the data field, the CRC Error 
Status Bit is set, and the command is 
terminated (even if it is a multiple record 
command). 
At the end of the read operation, the 
type of data address mark encountered 
in the data field is recorded in the Status 
Register (Bit 5) as shown: 


.7 
_ 
7 
ii 
1 
STATUS BIT 5 


I 
1 
Deleted Data Mark 
0 
Data Mark 


WRITE SECTOR 
Upon receipt of the Write Sector 
command, the Busy status bit is set. 
When an ID field is encountered that 
has the correct track number, correct 
sector number, and correct CRC, a DRO 
is generated. The VL1772-02 counts off 
11 bytes in single density and 22 bytes 
in double density from the CRC field and 
the Write Gate (WG) output is made 
active if the DRO is serviced (i.e., the 
DR has been loaded by the computer). 
If DRO has not been serviced, the 
command is terminated and the Lost 
Data status bit is set. If the DRO has 
been serviced, the WG is made active 
and six bytes of zeros in single density 
and 12 bytes in double density are then 
written on the disk. At this time, the data 
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FIGURE 3. TYPE II COMMAND FLOWCHART (Cont.) 


HAVE 
YES 
5 |NDEx HQLES 
INTRO, RESET BUSY 
pAsSED 
SET RECORD-NOT FOUND 


? 


NO 


HAS 
ID AM 
BEEN 
DETECTED 
? 


YES 


DOES 
TR = TRACK 
ADDRESS OF ID 
FIELD 
? 


YES 


DOES 
SR = SECTO 
'DDRESS OF ID 
FIELD 
7 
YES 


BRING IN SECTOR LENGTH FIELD 
STORE LENGTH IN INTERNAL 
REGISTER 


'8 
NO 
SET CRC 
THERE A 
RESET 
STATUS ERROR 
CRC ERROR 
ciqc 
7 


IS 
COMMAND 
NO 
A 
WRITE 
READ 
7 
vss 
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FIGURE 3. TYPE ll COMMAND FLOWCHART (Cont.) 


READ SECTOR 
SEQUENCE 


HAS 
DATA AM 
NO 


. 
OCCURRED 
IN TIME 


YES 


. 
PUT RECORD TYPE IN 
STATUS REG BIT 5 


YES 


HAS 
FIRST BYT 
EENASSEMBLE 
IN DSR 


YES 


SET DRO 


HAS 
NEXT BYTE 


3 EEN ASSEMBLE 
IN DSR 


YES 


HAS 
on seen 
no 
-READ ev COMPUTER 
SET DATA 


' 
(ono = 0) 
LOST 


HAVE 
ALL BYTES 
BEEN INPUTTED 


YES 


NO 
YES 
CRC 
NO 
ERROR 


YES 


+ 1 TO 
SECTOR REG 


INTRO, RESET BUSY 
' 
SET CRC ERROR 


INTRO RESET BUSY 
114 


VLSI TECHNOLOGY, INC. 
VL1772-02 


FIGURE 3. TYPE ll COMMAND FLOWCHART (Cont.) 


WRITE 
SEQUENCE 


DELAY 2 BYTES OF GAP. 


SET DRO 


DELAY 9 BYTES OF GAP 


HAS 
DR BEEN 
NQ 
LOADED av COMPUTER 
"""*°- RESET BUSY 
(DRO z 0) 
ser LOST DATA 


YES 


DELAY 
1 BYTE OF GAP 


YES 
TURN on we it WRITE 
5 BYTES OF ZEROES 
DELAY 11 BYTES 
\ 


WRITE DATA AM 


OF WRITE COMMAND 


DR TO DSR SET DRO 


WRITE BYTE TO DISK 


HAS 
235558 
NO 
SET DATA LOST 
WRITE BYTE 
(DRO = °l 
OF ZEROES 


HAVE 
ALL evrss 
YES 
BEEN WRITTEN 
WW5 CRC 


WRITE 1 evrs OF FF 


TURN OFF we 
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address mark is then written on the disk 
as determined by the a0 field of the 
command as shown below: 


_;_q 
7 
— 
I-I— 
1- 
—I’ 
in 


_ so 
DATA ADDRESS MARK_(BlT Q) 


1 
Deleted Data Mark 
0__ 
_DatzLMark 
_ 
__ 
1 


The VL1772-02 then writes the data eld 
and generates DRQs to the computer. If 
the DRQ is not serviced in time for 
continuous writing, the Lost Data Status 
Bit is set and a byte of zeros is written 
on the disk. The command is not 
terminated. After the last data byte has 
been written on the disk, the two-byte 
CRC is computed internally and written 
on the disk followed by one byte of logic 
ones in FM or in FMF. The WG output 
is then deactivated. INTRQ will set 24 
us (MFM) after the last CRC byte is 
written. For partial sector writing, the 
proper method is to write data and fill 
the balance with zeros. 


TYPE Ill COMMANDS 
Read Address - Upon receipt of the 
Read Address command, the Busy 
Status Bit is set. The next-encountered 
ID field is then read in from the disk; and 
six data bytes of the ID field are as- 
sembled and transferred to the DR, and 
a DRQ is generated for each byte. The 
six bytes of the ID field are shown 
below: 


so that a comparison can be made by 
the user. At the end of the operation an 
interrupt is generated and the Busy 
status is reset. 


Read Track - Upon receipt of the READ 
track command, the head is loaded and 
the Busy status bit is set. Reading 
starts with the leading edge of the first 
encountered index pulse and continues 
until the next index pulse. All gap, 
header, and data bytes are assembled 
and transferred to the Data Register and 
DRQs are generated for each byte. The 
accumulation of bytes is synchronized to 
each address mark encountered. An 
interrupt is generated at the completion 
of the command. 


This command has several characteris- 
tics that make it suitable for diagnostic 
purposes. They are: no CRC checking 
is performed; gap information is included 
in the data stream; and the address 
mark detector is on for the duration of 
the command. Because the AM detector 
is always on, write splices or noise may 
cause the chip to look for an AM. 


The ID AM. ID Field, ID CRC Bytes, 
DAM, Data and Data CRC Bytes for 
each sector will be correct. The Gap 
Bytes 
may be read incorrectly during write- 
splice time because of synchronization. 


mick 
sine 
szcron secron cnc cnc 
ADDR 
uunrresn 
ADDR 
LENGTH _1 
2 
__1 
2 
3 _ 
4___ 
5 
6 


Although the CRC characters are 
transferred to the computer, the 
VL1772-02 checks for validity and the 
CRC Error Status Bit is set if there is a 
CRC error. The track address of the ID 
field is written into the Sector Register 


WRITE TRACK FOFIMATTING 
THE DISK 
Data and gap information are provided 
at the computer interface. Formatting 
the disk is accomplished by positioning 
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the R/W head over the desired track 
number and issuing the Write Track 
command. 


Upon receipt of the Write Track com- 
mand, the Busy Status Bit is set. 
Writing starts with the leading edge of 
the first encountered index pulse and 
continues until the next index pulse, at 
which time the interrupt is activated. 
The Data Request is activated immedi- 
ately upon receiving the command, but 
writing will not start until after the first 
byte has been loaded into the Data 
Register. If the DR has not been loaded 
within three byte times, the operation is 
terminated, making the device Not Busy, 
the Lost Data Status Bit is set, and the 
interrupt is activated. If a byte is not 
present in the DR when needed, a byte 
of zeros is substituted. 
This sequence continues from one index 
mark to the next index mark. Normally, 
whatever data pattern appears in the 
data register is written on the disk with a 
normal clock pattern. However, if the 
VL1772-02 detects a data pattern of F5 
through FE in the data register, this is 
interpreted as a data address mark with 
missing clocks or CRC generation. 


The CRC generator is initialized when 
any data byte from F8 to FE is about to 
be transferred from the DR to the DSR 
in FM or by receipt of F5 in MFM. An F7 
pattern generates two CRC characters 
in FM or MFM. As a consequence, the 
patterns F5 through FE must not appear 
in the gaps, data fields, or ID fields. 
Also, ORCs must be generated by an F7 
pattern. 


Disks may be formatted in IBM 3740 or 
System 34 formats with sector lengths of 
128, 256, 512, or 1024 bytes. 


TABLE 2. DATA PATTERN DECODE 
oiit PATTER-I74 
I 
_ 
m on (HEX) 
IN FM (open 
-1) 


i 
i 
4| a 
l 
if 
i 


l 
E 
3 
IN MFM (DDEN - O) 


3 
1 
F 
1* 
E 
i 
4i 
_ 
00 thru F4 
A 
F5 
I Not Allowed 
F6 
Not Allowed 


Wrlte 00 thru F4 wlth CLK = FF 
Wrlte 00 thru F4, in MFM 


Wrlte C2“ In MFM 
F7 
I‘ Generate 2 CRC bytes 
F9 thru FB 
Wrlte F8 thru FB, CLK = C7, Preset 
CRC 
FC 
Wrlte FC with CLK = D7 
FD 
Write FD with CLK 
.—.= FF 
FE 
Write FE, CLK = C7, Preset CRC 


Generate 2 CRC bytes 


Write F8 thru FB, In MFM 
Write FC In MFM 
Write FD in MFM 
Wrlte FE In MFM 


I; Wrlte A1‘ In MFM, Present CRC 


_____ 
|=r=___ 
lrrire FFn CLK_:__fF 
_ 
y 
_ 
‘ WrIie_FF In__MFM __ 
_ 
‘Missing clock transition between bits 4 and 5. 
“Missing clock transition between blts 3 and 4, 
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TYPE IV COMMANDS 
The Forced Interrupt Command is 
generally used to terminate a multiple 
sector read or write command or to 
ensure Type I status in the status 
register. This command can be loaded 
into the command register at any time. 
If there is a current command under 
execution (Busy Status Bit set) the 
command is terminated and the Busy 
Status Bit reset. 


The lower four bits of the command 
determine the conditional interrupt as 
follows: 


I0 = Don't Care 
l1 = Don't Care 
I2 =- Every Index Pulse 
I3 = Immediate Interrupt 


The conditional interrupt is enabled 
when the corresponding bit positions of 
the command (I3-I0) are set to a 1. 
Then, when the condition for interrupt is 
met, the INTRO line goes high signifying 
that the condition specified has oc- 
curred. If I3-IO are all set to zero (HEX 
DO), no interrupt occurs but any com- 
mand presently under execution is 
immediately terminated. When using 
the immediate interrupt condition (I3 = 1) 
an interrupt immediately is generated 
and the current command terminated. 
Reading the Status or writing to the 
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when there is a current command under 
NUMBER 
execution, the Busy status bit is reset, 
OF BYTES 
DEX VALUE OF BYTE WMTTEN 
and the rest of the status bits are 
unchanged. If the Force Interrupt 
command is received when there is not 
a current command under execution, the 
Busy Status Bit is reset and the rest of 
the status bits are updated or cleared. 
in this case, Status reflects the Type I 
commands. 


The user has the option of reading the 
status register through program control 
or using the DRO line with DMA or 
interrupt methods. When the Data 
Register is read the DRO bit in the 
Status Register and the DRO line are 
automatically reset. A write to the Data 
Register also causes both DRO's to 
reset. 


The Busy Bit in the status may be 
monitored with a user program to 
determine when a command is com- 
plete, in lieu of using the INTRO line. 
When using the INTRO, a Busy status 
check is not recommended because a 
read of the Status Register to determine 
the condition of busy resets the INTRO 
line. 


The format of the Status Register is 
shown below: 


1 
'1 
40 
FF (or 00) 
6 
00 
FE (ID Address Mark) 
Track Number 
Side Number (00 or 01) 
Sector Number (1 thru 1A) 


I 
00 (Sector Length) 
Fl (2 CRC’s written) 
FF (or 00) 
—L 


—LO>—L—L—L_L—L—L—L 
FB (Data Address Mark) 
128 
Data (IBM uses E5) 
1 
F7 (2 CRC’s written) 
__1Q 
FF (or 00) 
369“ 
_FF (or 00) 
H 
K 


(BITS) 


. 
. 
7 
6 
Command Register does not automat|- 
~ 
5 
4 -- 
cally clearthe interrupt. The HEX D0 is 
the only command that enables the 
immediate interrupt (HEX D8) to clear 
on a subsequent load command register 
or read status register operation. Follow 
a HEX D8 with D0 command. 


Wait 16 us (double density) or 32 p.s 
(single density) before issuing a new 
command after issuing a forced inter- 
-OP9"""°" 
l N°"t °p°"“'°..'L.~ 
FM 
ME 
fupt 
Loading a new command sooner 
Wrlte (O 
Read BUSY Bit 
48[,1S8C 
24|.4S8C 
than this nullifies the forced interrupt. 
C°miTi3Qd R‘-*9 
(SW5 Bit 0) 
.4 
. 
Write to 
Read Status 
64psec 32pS9C 


S7 
S6 
S5 
S4 
S3 
S2 
S1 
S0 


Because of internal synchronization 
cycles, certain time delays are observed 
when operating under program I/O as 
shown. 


Delay Req'd. 
I 
24 
M 
66800 


to be written, there is one Data Request. 


“Continue writing until VL1772-02 
interrupts out. Approximately 369 bytes. 


256 BYTES/SECTOR 
Shown below is the recommended dual- 
density format with 256 bytes/sector. In 
order to format a diskette the user must 
issue the Write Track comand and load 
the data register with the following 
values. For every byte to be written, 
there is one data request. 


I"'__ 
|_‘Illr__ 
r' 
__'|L 
”_ 
NUMBER 
OF BYTES 
HEX, VALUE OF BYTE WRITTEN 
i 
4E 
12 
00 
3 
F5 (Writes A1) 


. 
FE (ID Address Mark) 
Track Number (0 thru 4C) 


. 
Side Number (0 or 1) 
Sector Number (1 thru 1A) 
01 (Sector Length) 
F7 (2 CRC’s written) 
4E 


IO 4'“ 


_L8_;(,)|\)|\)_;_L_;_;_;_; 


00 
F5 (Writes A1) 
FB (Data Address Mark) 
DATA 
F7 (Data Address Mark) 
4E 
4E, L 
i 


Force Interrupt Command stops any 
Command Reg 
Bus 1,, 
** Continue writing until VL1772-02 
command at the end of an internal micro 
5* 
* 
an 
T 
5 
interrupts out. Approximately 668 bytes. 
. 
1 
. 
d 
IN R 
h 
Write 
Read Same 
32psec 16pS8C 
ms rucuon an 
generates 
T Ow en 
Register 
, Register 
Non-Standard Formats -Variations in 
the specified condition is met. Force 
~ ~ 
— 
Interrupt waits until ALU operations in 
progress are complete (CRC calcula- 
tions, compares, etc.). 


Status Register 
— Upon receipt of any 
command, except the Force Interrupt 
command, the Busy Status Bit is set and 
the rest of the status bits are updated or 
cleared for the new command. If the 
Force Interrupt Command is received 


RECOMMENDED - 126 BYTES! 
SECTOR 
Shown below is the recommended 
single-density format with 128 bytesl 
sector. In order to format a diskette, the 
user must issue the Write Track 
command, and load the data register 
with the following values. For every byte 
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the recommended formats are possible 
to a limited extent, if the following 
requirements are met: 


1) Sector size must be 126,256,512 or 
1024 bytes. 


2) Gap 2 cannot be varied from the 
recommend format. 


3) Three bytes of A1 must be used in 
MFM. 
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In addition, the Index Address Mark is 
___ 
__ 
F" 
"FM 
not required for operation by the 
' 
Gap I 
16 bl/18$ FF 
32 W198 4E 
VL1772-02 Gap 1, a, and 4 lengths can 
Ga? " 
lg ,5,/,‘°s 50" 
g E"? 35 
be as short as two bytes for VL1772-02 
- 
as 
3 byiltessA1 
operation; however, PLL lock up time, 
Gap Iii" 
10 bytes FF 
24 bytes 4E 
motor speed variation, write-splice area, 
4 bl/18$ 00 
3 bytes 00 
etc._add more bytes to each gap_to 
Gap IV 
16 bytes FF 
1% gig: 


8Chl8V8 pfOp8|' Op8f8tlOn. 
FOP highest 
system reliability, use the recommended 
‘Byte counts must be exact. 
_ 
format 
“Byte counts are minimum, except exactly 3 bytes 
of A1 must be written. 


TABLE 3. STATUS REGISTER 


L 
I‘ 1 
I 
i 
l 
_ 
4i 
l 
i 
Ii 
i i 
BIT NA_M_E 
MEANING 
1 
__ 
__ 
S7 MOTOR ON 
This bit reflects the status of the Motor On output. 
'3 
I__ 
h 
ii 
_ 
E 
S6.WRITE PROTECT 
On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates 


. _ 
,... 
a ‘it? E"°i@'°L1‘.i_$ bi‘ ‘$_"*_'="“-?‘w"e"_l1Pda‘ed- 
._ 
_.___.._....___. 
S5 RECORD 
When set, this bit indicates that the Motor Spin-Up sequence has completed 
TYPE/SPIN-UP 
(5 revolutions) on Type I commands. Type 2 & 3 commands, this bit indicates record 
__.__.__ 
._IYPe- ° W1" °aia.Ma".<= 
_ 
__._ 
- 
_ 
S4 RECORD NOT 
When set, it indicates that the desired tra-(R sector, or side were not found. This 
FOUND (RNF) 
bit is reset when updated. 
_ 
l 
___ 
_ 
S3 CRC ERROR 
1 
I if S4 is set, an error is found in one or more ID fields; othenrvise it indicates 
error data field. This bit is reset when updated. 
S2 LOST DATA! 
‘I When set, it indicates the computer did not respond to DRO in one byte time. 
BYTE 
This bit is reset to zero when updated. On Type I commands, this bit reflects the 
status of the TR00 signal. 
i 
1 
I 
f§q ‘I 
j E 
I i 
1 
S1 DATA REQUEST 
I This bit is a copy of the DRO output. When set, it indicates the DR is full on a 
INDEX 
Read Operation or the DR is empty on a Write operation. This bit is reset to zero 
when updated. On Type 1 commands, this bit indicates the status of the IP 
__ 
__ 
y 
l Slgnal. 
y. 
_ 
_____________ 
S0 BUSY 
I When set, command is under execution. When reset, no command is under 
execuon. 


l‘__I 
I 
II 
i 
is 
1 
it 
$7 
i 
1 
i 
1 
i 
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FIGURE 4. TYPE Ill COMMAND WRITE TRACK FLOWCHART 


ENTER 


IS 
THIS A 
WRITE TRACK 


YES 


set eusv, asset ono, 
LOST DATA STATUS 
BITS 4. s 


set M0 


NO 


DELAY 6 
INDEX PULSES 


NO 


YES 


HAS 
INDEX 
PULSE 
OCCURRED 


HAS 
30 MS 
YES 
EXPIRED 


YES 


YES 
INTRO RESET 
BUSY SET WPRT 


NO 


SET DRO 


DELAY 3 BYTE 
TIMES 


set mrao 
No 
HA5 
LOST DATA 
DRQ BEEN 
RESET eusv 
SE“)/‘CE 


YES 
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DR TO DSR 


SET DRO 


VL1772-02 
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FIGURE 4. TYPE III COMMAND WRITE TRACK FLOWCHART (Cont.) 


YES (MFM) 


NO (FM) 


0°55 
YES 
wane 2 cec 
DSR = F7 


DOES 
DSR = FC 


DOES 
DSR = FD, FE. 
OR F8-FB 


WRITE DSR 
C 
= 
FF 
I'- 


mrno RESET 
YES 
PHYS 
eusv 
mosx MARK 


YES 
HAS 
DR BEEN 
LOADED 


DOES 
DSR = F5 


DOES 
DSR = F6 


DOES 
DSR = FF 


wane osa 
IN MFM 
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O ~1 


CHARS CLK = FF 


WRITE FC 
CL 
= D7 


WRITE FD FE OR 
F8 F9 CLK = 
INITIALIZE CRC 


WRITE 
BYTE OF ZEROES 
SET DATA LOST 


YES 
WRITE A1 IN MFM 
WITH MISSING 
CLOCK INITIALIZE 
CRC 


WRITE C2 IN MFM 
WITH MISSING 
CLOCK 


WRITE 2 CRC 
CHARS. 


VL1 772-O2 
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TABLE 4. READ DATA TIMING 


O 
CHARACTERISTIC 
MINT 
TYPb;” MAX lumrs 
I 
couomous 


1 
I"1__' ' 
_ 
r_ __ 
l_ 
5 
Raw Read Pulse Width 
.200 
3 
IJSBC 
MFM 
.400 
_ 
3 
FM 
Raw Read Cycle Time 
1 
3 
IJSGC 
if 
T' 
1 
1 


TABLE 5. READ ENABLE TIMING 


READ ENABLE TIMING - E such that: R/W = 1, cs = 0. 


l 
1 
1 
1 
| 
I 
i 
@ 
M 
M 
M 
SYMBOL 
_ 
__CHARACTERlSTlC 
MIN 
_ 
_ 
MAX 
UNITS 
J 
COND_l_'I:lONS 


tRE 
I RE Pulse Width cf_CS 
_ 
200 
nsec 
CL: 50 pf 
tom 
DRO Reset from_1E 
‘ 
200 
300 
nsec 
rm, 
Data Valid from RE 
100 
' 
200 
I 
nsec 
cL= so pf 
tDOH 
Data Hold from RE_ 
20 
150 
nsec 
CL: 50pf 
INTRO Reset from RE 
8 
[.1880 
..._. 
..._... 
. 
. $ 
I 
.........‘...... 
A 
. 


Note: Worst case service time for DRO is 23.5 IJSGC for MFM and 47.5 nsec for FM. 


FIGURE 5. READ ENABLE 'I'IMING 


DALS 
VALID 


0-7 


iov 
IDOHA 


i 1 
F 


IDRR 


DRO*—” 
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TABLE 6. WRITE ENABLE TIMING 


WRITE ENABLE TIMING - WE such that: R/W = 0, E = 0. 


M 
L 
Iii}: 
1 
1 
ii 
L 


VL1 772-02 


u_S_YlMBOL 
M__CHARACTER_l_SlI_C 
_ 


1. ’ 
n 
r** 
n 
W. _ 
' 
El 
7 
' 
_MlN 
TYP 
~ 
MAX 
1 UNITS 
CONDITIONS 


tAS 
Setup ADDR tc>_CS 
tag 
Setup RNV to CS_ 
tAH 
Hold AIER fron_1___CS 
. 


IHLD 
ITQITI 


IWE 
PUISG 
___ 
tDRw 
DRO Reset fror_r_1___WE 
tDS 
Data Setup to W_E_ 
tDH 
Data Hold from WE 
' INTRO Reset from WE 


0 
10 
0 
200 


150 
0 
. 


I 
71 
I 
so 
R 
I 


100 
200 
~ 
nsec 


I 
I 


I‘! 
T’ I 
7 
_ 
_' 
"E 
nsec 
nsec 
nsec 


- 
nsec 


' 
nsec 


DSBC 


FISGC 
-8. 
_ 
1182.9. 


FIGURE 6. WRITE ENABLE TIMING 


i 
1 
4i’ 


ios 
‘DH 


J-in 
1 


oA 


F5 
IWE __.._...._......_ 


isET—>| 
l>I 
Ff Ii-ILD 


R/W 
\ 
/ 


1AS_-I 
'<— 
1AA_>| 
'<-_ 


DRO 



ioRw 


' 
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TABLE 7. WFHTE DATA T|M|NG 


§|v|B5L_ 
I 
CHARACTERISTIC I _ 
_|v||l|\| 
TYP 
MAX 
uurr; 
c_:'cT|\i0|T|o:§§ 


Write Gate to Write Data 
I 
4 
A 
FM 
2 
pS6C 
].4S6C 
MFM 
Write Data Cycle Time 
4,6,8 
|.4S8C 
3 


- Write Gate off from WD 
‘ 
4 
1,1890 
FM 
| 
l 
2 
‘ 
psec 
MFM 
twp 
Write Data Pulse Width 
820 
nsec 
Early MFM 


| 
690 
F 
\ 
nsec 
— 
Nominal MFM 


l 
570 
nsec 
Late MFM 
1.38 
|.4S8C 
FM 
A 
1 i j 
A 
‘I i 
D 
A 
I 
A 
i 
L 


FIGURE 7. WRITE DATA TIMING 


—l> 


i.__.ZD_i-> 


—> 
/| 
7¢LK$; 
-- 
-- 
--_ 
- 
-—-—-—->\ 


EARLY!“/p 


/ | 11 FQR FM 
\ 


NOMlNALlwp 


_______/|;—--——— 
———-————-|\ 
LATElwp 
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TABLE 8. MISCELLANOUS TIMING 


VL1 772-O2 


A 
I 
I11 *'1 
_i 
1 
Z 
1 
1 
pi 
Q 
I7 i 
M 
1 
M 
A 
A 
_ 
1’ 
1 
i 
SYMBOL 
L 
CHARACTERISTIC 
MIN 
L 
TYP 
I 
MAX. 
UNITS 
CONDITIONS 
..._ 
-4 
up 
_ 
_l' 
. 
r. 
__ 
_ 
.... 
__ 
.T__ 
__ 
._._ 
_ 
_. 
_. 


tc01 
I002 
tSTP 


tom 


tMFl 
t|P 


Clock Duty (low) 


, CLock Duty (high) 
Step Pulse Output 


L Dir Setup to Step 
| 
48 
Master Reset Pulse Width 
' 
50 
r 
I 
psec 
- 


‘ Index Pulse Width 
20 
L 
[.4580 


50 
67 
nsec 


- 
50 
I 
67 
I 
' 
nsec 
I 


I 
4 
psec 
| 
3 
~ 
~ 
24 
psec 


MFM 
FM 
MFM 
FM 


M 
—_' 
I-— 
r 
_ 
1 
1 
1 
I 
Q 
i 
41 
1 
1 
A 
j 
— 
j 
A 
A 


FIGURE 8. MISCELLANOUS TIMING 


|<——"P—-l 


‘<- ICYC -0| 


CLK 


-._i>| ICQ 
_Ll_l_ 


l~— 


l~—~R—-I 


l~ »l 


4- 
1 0 —> 


ISTP I4-—-ul ISTP I4-— 
I<- loin-0-I ism |<—- 
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FIGURE 9. FORMATS 


moex 
I 
I 


PULSE 
" "" " " "' 
REPEATED 
|<—-— 
1 
1 -- 
FOREACH secrona 
I 
- 
Fl ,| 


40 evrss 
e evrss 
TRACK 
sscron LENGTH 
cec 
cnc 
11 evtss 
6 evrss 
0*“ 
usse DATA 
cec 
cnc 
10 evtes 
‘FF’ 
'00" 
ii 
ii 
ii 
1 
2 
'FF‘ 
-00' 
*0" 
12a BYTES 
1 
2 
'FF‘ 
MARK 


L 
P -~" 
J-I0 FIELD 
I 
I-ii-DATA Fietoii 


WRITE GATEQ 
L -. .- 
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SINGLE DENSITY FORMAT 


mocx 
I 
I 
PULSE 
- - - - - - 
REPEATED 
I4-— 
I 
o 
L- 
D- 
FOREACHSECTOR 
A 
ea 
' 
4 
I 
. ,, 
11"., 
1-,‘ 


GOBYTES 12 ewes aevtcs 
TRACK 
ssctoe LENGTH cnc cec 22 ewes 12 evtss sevrzs 
I0 
ussn DATA 
cnc cec 
24 evrss 
'46‘ 
‘00' 
'A1‘ 
ii 
iv 
ii 
1 
2 
-4:‘ 
'00‘ 
‘A1‘ 
‘F8’ 
255 BYTES 
1 
2 
-4:" 
; 
io FIELD 
I 
mm FIELD 


WRITE GATEA 
L ___ 


DOUBLE DENSITY FORMAT 
_ 


ABSOLUTE MAXIMUM RATINGS 
Ambient Operating 
Stresses above those listed under 
operational sections of this specification 
Temperature 
-10°C to +80°C 
"Absolute Maximum Ratings“ may cause 
is not implied and exposure to absolute 


_ 
0 
O 
permanent damage to the device. These 
maximum rating conditions for extended 
storage Temperature 
65 C to +140 C 
are stress ratings only. Functional 
periods may aect device reliability. 
SUPPIY V°|ia9° I0 
operation of this device at these or other 
GT°U"d P°19"IIaI 
-0-5 V I0 +7-0 V 
conditions above those indicated in the 


Applied Output 
Voltage 


Applied Input 
Voltage 


Power Dissip 


-0.5 V to +7.0 V 


-0.5 V to +7.0 V 


ation 
800 mW 


DC CHARACTERISTICS TA = o<>c to 1o=>c, vcc = s v 1 s</. 
. 
Symbol 


VOH 


VOL 


VIH 


VIL 


llL 


IOL 


RPU 


ICC 


PD 


Parameter 
T 


o 
3 


Output High Voltage 


Output Low Voltage 


Input High voltage 


Input Low Voltage 


Input Leakage Current 


Output Leakage Current 


Internal Pull up 
1700 


Operating Supply Current 


Power Dissipation 
m 


1 25 


Conditions 


IO .. -100 “A 


IO - 1.6 mA 


VIN 1- VCC 


VOUT §-- VCC 


VIN =1 O V 
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APPLICATION INFORMATION 
VL1 772-O2: AN IMPROVED 
VERSION 
OF THE 1 770-O0 
The 177X family of flexible disk control- 
lers has attracted a great deal of interest 
from system designers. Allowing 
compactness and superior performance, 
this family of advanced lCs has proven 
to be a success in the marketplace. The 
original 1770-00 won much approval 
with its 28-pin package. Its digital data 
separator allowed consistent operation 
over temperature, but more was 
required. The error rate of this data 
recovery circuit was too high, and a 
reliable data separator with lower error 
rates was seen as an important need for 
computer systems ofallt pes. ln 
Y 
addition, a small change of step rate 


FIGURE 10. WINDOWING READ DATA 


selections could ensure faster through- 
put, while maintaining compatibility with 
existing designs. 


Thus began the design of anew concept 
in flexible disk controllers. An important 
need was to maintain compatibility with 
existing designs using the 1770-00, 
while extending the capabilities of the 
177X family to include higher-perform- 
ance drives. These criteria have been 
satisfied with the VL1772-02. 


IMPROVING THE DATA 
SEPARATOR 
The improvement of the data separator, 
or data recovery circuit, as it is called, is 
an important enhancement to the 
reliability of the VL1772-02. The 


Clock 
__\ 1:; 
_ Clock 
x \ 
\\\\// 


TABLE 9. STEP RATE SELECTION: 1 770-O0 
AND VL1 772-O2 


Step Rate Select Bits 
Step Rate (ms) 


1770 


QQ 
3 


co5'°0 


0 


onto‘,3 
oz 


I 


1 


1 


VL1772 02 


1 26 


VL1 772-O2 


operation of this part of the circuit, 
although critical to system reliability, is 
simple to understand. Figure 10 shows 
a train of read data pulses coming from 
a floppy drive. The clock and data 
pulses are both in this signal, combined 
in a simple encoding format. In each bit 
cell, the data separator chooses a time 
period within which pulses are recog- 
nized as data pulses. The better the 
resolution for defining this window for 
the data pulses, the greater the jitter in 
the signal can be before ones and zeros 
are incorrectly recognized. This 
incorrect recognition, and the resultant 
soft errors, are the basic limiting factor in 
floppy drive error rates. The VL1772-02, 
with a wider data window, has a lower 
chance of incorrect recognition, resulting 
in lower error rates. This effect will be 
particularly evident as the user's media 
degrades with use and jitter increases. 
This increased reliability of the VL1772- 
02 can result in fewer returns and 
greater user satisfaction. 


STEP RATES 
With a different selection of step rates 
than the 1770-00 (see table 9), the 
VL1772-02 allows the use of drives with 
minimum settle times up to 12 ms. At 
the same time, performance is en- 
hanced to take advantage of floppy 
drives that require only 2 or 3 ms of 
delay. If a design is currently using 
head settle times of 6 or 12 ms (as most 
are), no modifications are required to 
use the VL1772-02 in the 1770-00 
socket. If the current choice of r1 and r0 
calls for 20 or 30 ms of delay, use of the 
VL1772-02 requires: 
— the selection of drives that have 
head settle time under 12 ms, and 
modified software to allow correct r1, r0 
choice, or 
— implementation of head settle time in 
hardware, with an external interrupt. 


Fortunately, almost all modern flexible 
disk drives have head settle times well 
under 12 ms, and current 1770 applica- 
tions have taken this into account, using 
6 or 12 ms as the head settle time. 
Where this change is required, it will 
mean less waiting for the drives to finish 
each seek. This will certainly produce 
higher user satisfaction with the system, 
as well as appreciably higher perform- 
ance against most benchmarks. 
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FEATURES 
- HDLC, SDLC, ADCCP and CCITT 
X.25 Compatible 


- SDLC Loop Data Link Capability 


- Full or Half Duplex Operation 


- DC to 2.0 Mbits/Sec Data Rate 


- Programmable/Automatic FCS (CRC) 
Generation and Checking 


- Programmable NRZI Encode/Decode 


- Full Set of Modem Control Signals 


- Digital Phase Locked Loop 


- Fully Compatible with Most CPU's 


- Error Detection: CRC, Underrun, 
Overrun, Aborted or Invalid Frame 
Errors 


- Straight Forward CPU Interrupts 


- Programmable Modem Control 
Interrupts 


- Double Buffering of Data 


- Variable Character Length (5, 6, 7 or 8 
Bits) 


- Residual Character Capability 


- Address Compare 


PIN DIAGRAM 


VL1935 


REOM III 
4o -i go 
Ecg _ 
as - co 
N-A 
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SYNCHRONOUS DATA LINE CONTROLLER 


- Global Address Recognition 


- Extendable Address Field 


- Extendable Control Field 


- Automatic Zero Insertion and Deletion 


- Maintenance Mode for Self-Testing 


- Pin-Compatible Replacement for WD 
1933 and WD1935 


DESCRIPTION 
The VL1935 is a MOS/LSI microcom- 
puter peripheral device which performs 
the functioning of interfacing a parallel 
digital system to a synchronous serial 
data communication channel employing 
lSO's HDLC, IBM's SDLC or ANSl's 
ADCCP line protocol. These protocols 
are referred to as Bit-Oriented Protocols 
(BOP). 


The chip is fabricated in N-channel 
depletion load MOS technology and is 
TIL compatible on all inputs and 
outputs. This controller requires a 
minimum of CPU software by support- 
ing a comprehensive frame-level 
instruction set and by hardware 


ORDER INFORMATION 


Pall 
Clock 
Numbef 
Frequency 
Package 


Plastic DIP 
0.5 MHZ 
Plastic Leaded Chip Carrier (PLCC) 
VL1935-10PC 
VL1935-1OQC 
BE 
cs 
MISC OUT 
i~1;B.Q 
we 
22 
2.1. 
2.2. 
9.2 
24. 
2.5. 
.i:.>_§ 
_°.Z 
m 
DTR 
DRO0 
DRO1 
GND 


Q 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 


929. 
931 
IE2 
_I1l_1 
RI 
2% 
_l1[_S 
'rc_ 
1x/szx 
9.]§. 
NRZI 
B9. 
E2 
TD 
yi__i_sc IN 
Al. 
Ai 
A2 


VL1 935-1 OCC 


VL1935-11PC 
VL1935-11OC 
VL1935-11CC 


VL1935-12PC 
VL1935-12OC 
VL1935-12CC 


VL1935-13PC 
VL1935-13QC 
VL1935-13CC 


implementation of the low level tasks 
associated with frame assembly! 
disassembly and data integrity. It can 
be programmed to encode/decode 
NRZI data. The internal clock is then 
derived from the NRZI data using a 
digital phase locked loop. 


The receiver and transmitter logic 
operates as two total independent 
sections with a minimum of common 
logic. The frames are automatically 
checked for errors during reception by 
verifying correct Frame Check Se- 
quence (FCS). In transmit mode, the 
FCS is automatically generated by this 
controller and sent before the final Flag. 
It also continuously checks for other 
errors. In case of an error, the CPU is 
interrupted. 


The controller recognizes and can 
generate Flag, Abcrt, Idle and GA 
characters. VL1935 can be used in an 
SDLC Loop configuration. An End of 
Block option is supplied to minimize 
CPU time. A full set of modem control 
signals are supplied to minimize 
external hardware. 


Ceramic DIP 


Plastic DIP 
1.0 MHz 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 


Plastic DIP 
1.5 MHz 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 


Plastic DIP 
2.0 MHz 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 


Note: Operating temperature range is 0°C to +70°C. 


S 


PIN DESCRIPTION 


E2z2 


1 


2 


3 


4 


5 


6 


7 


8thru15 


16 


17 


18 


19 


20 


21 thru 23 


24 


25 


26 


27 


28 


29 


30 


31 
128 


REOM 


EOB 


RE 


cs 


Received End 
of Message 


End of Block 


Read Enable 


Chip Select 


MISC OUT 
Misc Output 


INTRO 


‘WE 


cm 07 
MR 


DTR 


DRQO 


DRQI 


Vss 
A§JiATr 


AMSCIN 


TD 


R6 
no 


NRZI 


CTS 


-ii 
1 X/32X 


T6 


Interrupt 
Request 


Write Enable 


Data Bus 
I 
Master Reset 


Data Terminal 
Ready 


Data Request 
Output 


Data Request 
Input 


Vss 
ADDRESS 


Misc Input 


Transmitted Data 


Receive Clock 


Received Data 


NRZI 


Clear to Send 


DPLL Select 


Transmit Clock 
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BER 
SIGNAL NAME 
FUNCTION 


Received End of Message with no Errors. This output signal is 
the inverse of IR7, bit 7 of the Interrupt Register. 


Thgnput, when low, function as an FCS command. ls independent 
of CS. 
This input, when low (and CS is active), gates the content of ad- 
dressed register onto the Data bus. 


This input, when low, selects the VL1935 for a read or write operation 
to/from the Data bus. 


This output is an extra programmable output signal for the conve- 
nience of the user. ls controlled by the CR10 bit. 


This output is high whenever any of the interrupt register bits IR7-lR3 
are set. TC must be asserted to assert INTRO. 
A 
This input when low (and CS is active), gates -the content of the Data 
bus into the addressed register. 


Bidirectional three-state Data Bus. Bit 7 is MSB. 


This input, when low, initializes all the registers, and forces the 
VL1935 into an idle state. The VL1935 will remain idle until a com- 
mand is issued by the CPU. 
Modem Control Signal. This output, when low, indicates to the Data 
Communication Equipment (DCE) that the VL1935 is ready to trans- 
mit or receive data. 


This output, when high, indicates that the Transmitter Holding Register 
(THR) is empty and ready to receive a data character from the Data 
bus for a transmit operation. 


This output, when high, indicates that Receiver Holding Register 
(RHR) contains a newly received data character, available to be read 
onto the Data bus. 


Ground 


These inputs are used to address the CPU interface registers for readl 
write operations. 


This input is an extra input signal for the convenience of the user. The 
state is shown by the SR4 bit. 
This output transmits the serial data to the Data Communications 
Equipment/Channel. 


This input is used to synchronize the received data. 
This input receives the serial data from the Data Communication 
Equipment/Channel. 


This input, when low, sets the VL1935 in NRZI mode. 


Modem Control Signal. This input when low, indicates that the DCE is 
ready to accept data from the VL1935. 


This input controls the internal clock. When high (1X clock), the ex- 
ternal clock has the same frequency as the internal clock. When low 
(32X clock), the extemal clock is 32 times faster than the internal clock 
and the DPLL Logic is enabled. 


This input is used to synchronize the transmitted data, as well as gen- 
erating either Receive or Transmit lNTRQ’s. 


NY 


PIN DESCRIPTION (continued) 


PIN 
NUMBER 
MNEMONIC 
SIGNAL NAME 
FUNCTION 


32 
T 


33 


34 


35 
36 


37 
38 


39 


40 


TERM 


BOP 


ABORT 


GA 


LSB 


MSB 


IDLE 


FLAG 


A-FIELD 


C-FIELD 


I-FIELD 


FCS 


FRAME 


WS 


DSR 


W 


Rl—1.RT6 


CD1, CDO 
Carrier Detect____ 


co 
I 


Vcc 
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Request to Send 
Modem Control Signal. This output, when low, indicates to the DCE 
that the VL1935 is ready to transmitdata. 


Modem Control Signal. This input, when low, indicates that the DCE 
is ready to receive or transmit data. 
Modem Control Signal. This input, when low, indicates a ringing signal 
being received on the communication channel. 


, 
Data Set Ready 


I 
Ring Indicator 


Ring Indicator 
These inputs are used to program Ring Indicator interrupts. 
Interrupt Control 


These inputs are used to program Carrier Detect Interrupts. 


‘ 
Interrupt Control 


Carrier Detect 
Modem Control Signal. This input, when low, indicates there is a car- 
rier signal received by the local DCE from a distant DCE. 


VCC 
‘ 
+5VDC 


_ 
1 
1 
l 
l 
i 
1 
M 
1 
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TABLE 1. 
VL1935 GLOSSARY 


I 
1 
1 
DEFINITION/DESCRIPTION 
Bit-oriented protocols: SDLC, HDLC, and ADCCP 


11111111 (seven or more contiguous 1's) 


Go-ahead pattern. 01111111 (0(LSB) followed by seven 1's) 


First transmitted bit and first received bit. (Least significant bit) 


Last transmitted bit and last received bit. (Most significant bit) 


1111111111111111(15 or more contiguous 1's) 


01111110. Starts and ends a Frame. 


Address-field in the Frame. Consists of one or more 8-bit characters. Defines the address 
of a particular station. 


Control field in the Frame. Consists of one or two 8-bit characters. 


Information field in the Frame. Consists of any number of bits. 


Frame Check Sequence. A 16-bit error checking field sequence. 
A communication element, consisting of a minimum of 32 bits, and delimited by FLAGS. 


GLOBAL ADDRESS 
An A-field character of eight 1's. When this is compared and matched in the Address com- 
parator, the DRQI will be set, indicating a valid address 


RESIDUAL 
The last I-field character, consisting of a lesser amount of bits than the other I-field char- 
CHARACTER 
acters in the Frame. 


DATA SET 
Data Communication Equipment (DCE). May be a modem. 


BIT TIME 
Length in time of a serial data bit. 


APPLICATIONS 
COMPUTER COMMUNICATIONS 
PACKET SWITCHING 


TERMINAL COMMUNICATIONS 
MULTIPLEXING SYSTEMS 


COMPUTER TO MODEM INTERFACING 
DATA CONCENTRATOR SYSTEMS 


LINE CONTROLLERS 
SDLC LOOP DATA LINK SYSTEMS 


FRONT END COMMUNICATIONS 
DMA APPLICATIONS 


NETWORK PROCESSORS 
COMMUNICATION TEST EQUIPMENT 


TELECOMMUNICATION SWITCHING NETWORKS 
LOCAL NETWORKS 


MESSAGE SWITCHING 
MULTIDROP LINE SYSTEMS 
129 
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FIGURE 1. 
VL1935 BLOCK DIAGRAM 
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A BRIEF DESCRIPTION OF HDLC, SDLC AND 
ADCCP PROTOCOLS 
The VL1935 is compatible with HDLC, SDLC and ADCCP 
standard communication Link Protocols. These are bit-ori- 
ented, code independent, and ideal for full duplex communi- 
cation. A single communication element is called a FRAME, 
which can be used for both link control and data transfer pur- 
poses. 
The elements of a frame are the beginning eight bit FLAG 
(F) consisting of one logical “ 0 " six 1's and a 0, an eight bit 
ADDRESS-FlELD(A), an eight bit CONTROL-FIELD (C), a 
variable (N bits) lNFORMATlON-FIELD, a sixteen bit FRAME- 
CHECK-SEQUENCE (FCS), and an eight bit end FLAG (F), 
having the same bit-pattem as the beginning flag. 
In HDLC, the address (A) and control (C) characters are 
extendable (more than one character). An .important char- 
acteristic of a frame is that its contents are made code trans- 
parent by use of a zero bit insertion and deletion technique. 
Thus, the user can adapt any format or code suitable for his 
system. The frame is bit-oriented, meaning that, bits not 


Figure 2. 
VL1935 TYPICAL SYSTEM INTERFACE 
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characters in each field have specific meanings. The Frame 
Check Sequence (FCS) is an error detection scheme similar 
to the Cyclic Redundancy Checkword (CRC) widely used in 
magnetic disk storage devices. The frame format is shown 
in Figure 3. 


FIGURE 3. 
VL1935 SDLC/HDLC/ADCCP 
FRAME FORMAT 
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Where: 
FLAG = 01111110 


Address field—One or more 8-bit characters defining the 
particular station 


Control field—One or two 8-bit characters 


Information field—Any number of bits (may be zero bits) 


Frame Check Sequence—16-bit error checking field 


The following features are also part of these protocols. 


ZERO INSERTION/ZERO DELETlON—Zero insertion/dele- 
tion is performed within the 2 Flags of a frame. If there are 
more than five1's in a row, a 0 is automatically inserted after 
the fifth 1 and it is deleted upon reception by the receiver. 


FRAME CHECK SEQUENCE (FCS)—A 16 bit cyclic redun- 
dancy check (CRC) calculation is performed during trans- 
mission of the data in between the 2 flags of the frame. The 
CRC is then transmitted after the I-field and before the final 
FLAG. Upon reception the receiver also performs a CRC 
calculation on the incoming data. If there were no transmis- 
sion error, the Receiver CRC equals F088 (hex). 
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HARDWARE ORGANIZATION 
The VL1935 block diagram is illustrated in Figure 1 and 
described below. 


CPU Interface Registers 
All of these registers are addressable and to be read from 
and/or written into by the CPU via the Data bus. These are 
8-bit registers and have to be enabled via Chip Select (CS) 
before any data transfer can be done. 
CONTROL REGISTER 1,2, 3 (CR1, 2,3) 
Operations are 
initiated by writing the appropriate commands into these reg- 
isters. CR1 should be programmed last. 
RECEIVER HOLDING REGISTER (RHR) 
When Data 
Request Input is set (DROl=1), contains received assem- 
bled character. 
ADDRESS REGISTER (AR) 
Contains the address of the 
accessed VL1935, which is to be compared to the received 
address character (A-field). 
INTERRUPT REGISTER (IR) 
Contains the cause of the 
current interrupt request. 
TRANSMITTER HOLDING REGISTER (THR) 
ls to be 
loaded with the next in line character to be transmitted, when 
Data Request Output is set (DROO=1). 
STATUS REGISTER (SR) 
Contains the overall status of 
the VL1935 
plus some information of the last received 
frame. 


Non-Addressable, Internal Registers 
These registers are transparent to the user, but is men- 
tioned in these data sheets to help the understanding of the 
VL1935. 
TRANSMITTER 
REGISTER 
(TR) 
This 
8-bit 
register 
functions as a buffer between the THR and the TD output. 
It is loaded from the THR (if Data Command) with the next 
character to be transmitted. A FLAG character may also be 
loaded into this register under program control. This 
character is automatically shifted out to the Transmit Data 
output. When the last bit of the current transmitted char- 
acter has left the TR register, a new character will be loaded 
in_to this register, setting DROO (Data command) or INTRO 
(Abort, Flag or FSC command). If at the time when only one 
bit remains left in the TR register, and the THR is not loaded 
or a new command is not programmed (Data command), an 
underrun error will occur. 
RECEIVER REGISTER (RR) 
The received data is, via 
the Zero-Deletion logic shifted into this 8-bit register. The 
data is here assembled to a 5, 6, 7 or 8-bit character length 
and then, under the right conditions, parallel transferred to 
the RHR register. 
FCS RECEIVE REGISTER AND FCS XMIT REGISTER 
The VL1935 contains a 16-bit CRC check register (FCS 
REC. REG.) and a 16-bit CRC generation register (FCS XMIT 
REG.). The generating polynomial is: 
G(X)=X‘°+X‘*+X‘+1 


The transmitter and receiver initialize the remainder value 
to all ones before CRC accumulation starts. The data is 
multiplied by X‘° and is divided by G()(). Inserted 0's are not 
included in the accumulation. Under program control, the 
complement called the frame check sequence (FCS) is sent 
with high order bit first. 
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Various Internal Circuits 
ADDRESS COMPARATOR 
This 8-bit comparator is used 
to compare the contents of the Address Register with the first 
address character of the incoming frame. This feature is en- 
abled by a bit in the Command Register. If enabled and there 
is a match, the received frame is valid and DROIs are gen- 
erated for every character received (including the A-field). If 
enabled and there is not a match or there is no Global Ad- 
dress, the received frame is discarded. If not enabled, all re- 
ceived frames are valid and DROls are generated. 
ZERO 
INSERTION 
The transmitted data stream 
is 
continuously monitored by this logic. A zero is automatically 
inserted following five contiguous 1 bits anywhere between 
the beginning FLAG and the ending FLAG of a frame. The 
insertion of the zero bit thus applies to the contents of the 
Address, Control, Information Data, and the FCS field. 
ZERO DELETION 
The received data stream is continu- 
ously monitored by this logic. Upon receiving five contiguous 


1 bits, the sixth bit is inspected. If the sixth bit is a 0, it is 
automatically deleted from the data stream. If the sixth bit is 
a 1, the seventh bit inspected; if it is a 0, a FLAG is recog- 
nized; if it is a_1_an_ABORT or GO AHEAD is recognized. 
DATA BUS (D7-D0) This is an inverted 8-bit bidirection 
al data bus. 
SDLC LOOP-MODE CONTROL 
This logic supervises 
the VL1935 running in SDLC Loop mode. It monitors the 
received data for a GO-AHEAD pattern in the case when 
SDLC LOOP MODE bit (CR22) and ACT TRAN bit (CR16) are 
set. When GO-AHEAD pattern is received, this logic sus- 
pends the repeater function and initiates the transmitter func- 
tion. For more details, see functional description of SDLC 
Loop Mode. 
NRZI ENCODER/DECODER 
When this mode is se- 
lected, the NRZI Encoder encodes the “normal" transmitted 
data to NRZI formatted data and the NRZI Decoder decodes 
the received NRZI data to "normal" data. 


A binary 1 for “normal data" is TD = high. 


A binary 1 for NRZI data is TD = no change. 


A binary 0 for “normal data" is TD = low. 


A binary 0 for NRZI data is TD = change of state. 


COMPUTER INTERFACE CONTROL 
This logic inter- 
faces the CPU, to the VL1935 . It supervises the read and 
write functions to the addressable registers, generates data 
requests and interrupts, decodes and initiates commands, 
monitors the status of VL1935, etc. 


MODEM INTERFACE CONTROL 
This logic interfaces 
and supervises the modem control signals to/from the 
VL1935 . It provides both dedicated (EIA Standard) and user 
defined control functions. 


CLOCK CONTROL 
This logic interfaces the transmit 
and receive clocks to the VL1935. It converts the external 
clocks to the necessary internal clocks. 


FUNCTIONAL DESCRIPTION 
SDLC Loop Mode 
The diagram below shows an SDLC Loop Data Link Sys- 
tem. VL1935 can be used in any ofthese stations. 
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FIGURE 4. 
VL1935 SDLC LOOP DATA LINK 


Secondary 2 


Each secondary station is normally a repeater in Receive 
mode (ACT REC bit on). The primary station is the loop con- 
troller. Signals sent out on the loop by the primary station are 
relayed from station to station, then back to the Primary. Any 
secondary station finding its address in the A-field captures 
the frame for action at that station. All received frames are 
relayed to the next station on the loop. 


If a secondary station wants to transmit a message, it sets 
the ACT TRAN bit (Eire must be low) and waits for a eo 
AHEAD (GA) pattern. The ACT REC bit must be asserted for 
detection of the GA and other existing patterns. Until the GA 
pattern is received, this secondary station continues operat- 
ing as a repeater. The primary station has the responsibility to 
generate the first GA pattern which can be accomplished by a 
flag followed by continuous 1's. The primary station must 
continue to send 1's until the GA has circulated through the 
entire loop. The first secondary station with its ACT TRAN bit 
set detects the GA and changes the last 1 bit of the GA pat- 
tern to a 0, thus generating the start flag of the frame it wants 
to transmit and preventing the GA pattern from propagating 
down the loop. The repeater function is then suspended by 
this secondary station and it goes into the transmit mode. 
When this secondary station completes its transmission 
frames, it resets the ACT TRAN bit and reverts back to the 
repeater mode. It repeats the 1's generated by the primary 
station to form another GA pattern from the final 0 of its end- 


FIGURE 5. 
VL1935 DPLL TIMING DIAGRAM 
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ing flag. The GA pattern propagates through the loop until a 
secondary station down the loop, that wants to transmit (ACT 
TRAN bit is set), intercepts the GA pattern and starts to trans- 
mit as described, or until the primary station receives the 
idles (continuous 1's), indicating that the GA pattern has cir- 
culated through the entire loop. The primary station then gen- 
erates another GA pattern or terminates its final data frame 
with continuous 1's. 
Repeaters (Secondary stations) delay the received data 
by 4 bits._(N RZ1 = 5 bits) before transmission. 
The RC andT_Oclocks must be tied together. The internal 
DPLL will not function in the loop mode. 


1X/32X Clock Option 
When -1X clock is selected, the data rate equals the ex- 
ternal clock (receiver and transmitter). 
When 32X clock is selected, the external clock rate is 32 
times faster than the data rate. 


Digital Phase Locked Loop (DPLL) 
This feature is particularly useful in NRZI mode and/or 
when asynchronous modem is used. The purpose of the 
DPLL is to synchronize the internal 1X clock to the received 
data, thus insuring that this data is sampled in the middle 
of the incoming serial data bit. DPLL is automatically in op- 
eration when 32X clock is selected. 
The DPLL Logic is initiated at the first received data 
transition in a frame. Corrections, if needed, are then made 
for each received data transition. A 32-counter is used for 
this operation. At the beginning of each frame and at the 
first received data transition, this 32 counter is reset. From 
this time on, the counter increments with one count for 
each external clock pulse. At count 16 the internal 1X clock 
is forced to change state to high (this transition = sam- 
pling time). At count 32, the counter resets itself. This 
forces the internal 1X clock again to change state back to 
low. 
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NOTE 1. FIRST DATA TRANSITION (FIRST FLAG) SETS THE DPLL COUNTER TO 01. 


NOTE 2. DATA TRANSITION IN BETWEEN HERE, OR NO DATA TRANSITION AT ALL, CAUSES NO CORRECTION OF THE 
DPLL COUNTER. 


NOTE 3. DATA TRANSITION IN BETWEEN HERE, WILL INCREMENT ONE COUNT TO THE DPLL COUNTER (ADD 01 TO 
WHAT IS SHOWN). 


NOTE 4. DATA TRANSITION IN BETWEEN HERE, WILL DECREMENT ONE COUNT TO THE DPLL COUNTER (SUBTRACT 01 
TO WHAT IS SHOWN). 
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At each received data transition, if the internal clock and 
the received data is out of synchronization, a correction is 
automatically made by :2 1 external clock period. See DPLL 
Timing Diagram in Figure 5. 


End Of Block (EOB) 
This is an FCS command. The main purpose of EOB is to 
allow the user to initiate FCS and FLAG without the need of 
using extra computer time. This is particularly practical in 
DMA applications. At the end of a frame, when the last in- 
formation data character has already been loaded into the 
THR and once again DROO is set, either a regular FCS com- 
mand is written into CR1 Register, or—EOB is to be activated. 
At the end of FCS, when INTRO is set (XMIT OPCOM), the 
iii 
EOB if activated is to be reset again. 


Serial Data Synchronization 
The serial data is synchronized by the externally sup- 
plied Transmit CIock(TC) and Receive Clock (T). When 1X 
clock is selected, the falling edge ofgenerates new 
transmitted data and the rising edge of RC is used to sam- 
ple the received data. When 32X clock is selected, a 32- 
counter (in th'e DPLL Logic) is used to synchronize the in- 
ternal clock. At time O, when the counter is reset to 0, the 
new transmitted data is generated. At time 16 (counter = 
16) the received data is sampled, insuring that sampling is 
done in the middle of the received serial data bit. At count 
32, the counter is reset to 0 again. 


Self Test (Diagnostic) Mode 
This feature is a programmable Loop back of data, ena- 
bling the user to make a complete test of the VL1935 with a 
minimum of external circuitry. In this mode, transmitted data 
to the TD pin, is internally routed to the received data input 
circuitry, thus allowing a CPU to send a message to itself to 
verify proper operation of the VL1935. The modem control 
signals OT-R_and 'RTS'are deactivated (off) to insure no inter- 
ference to/from the Data Communication Equipment (DCE). 
DSR and 'S'3r_e internally activated for proper input condi- 
tions. TC and RC should be supplied by the same source if 1X 
clock is selected. 


Auto Flag 
If this is selected and Data Command is executed, contin- 
uous Flags will be sent between frames. This eliminates the 
need to execute the Flag Command. In DMA applications in 
particular, this is very practical. 


Extended Addressing 
This type of addressing means, that there is more than one 
address character in the A-field. In receive mode, the first 
address character is compared in the Address Comparatorof 
the VL1935. The other address character/s is to be com- 
pared by the CPU. The last address character is recognized 
by the fact that the LSB (bit 2°) is a 1. 


PROGRAMMING 


Controlling Operation 
Prior to initiating data transmission or reception, CON- 
TROL REGISTER 1-3 (CR1-3) must be loaded with control 
information from the CPU. The contents of these registers 
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will configure the VL1935 for the user's specific data com- 
munication environment. These registers should be loaded 
during power-on initialization and after a reset operation. 
They can be changed at any time that the respective trans- 
mitter or receiver is deactivated. The CR1-3 dictate what the 
transmitter will send: the type of character (DATA, -ABORT, 
FLAG or FCS), the number of bits per character, and the num- 
ber of bits in the residual character. Similarly, they tell the 
receiver the types of frames to look for: the number of bits per 
I-field character, whether to perform an address compare, 
and whether to watch for an extended address. The Control 
Register also control Data Terminal Ready (DTR), Misc Out 
and the activation of both the transmitter and the receiver. For 
more detailed information, see Register Formats. 


Monitoring Operation 
Monitoring is done by use of the Interrupt Register (IR) and 
Status Register (SR). The IR register indicates when a frame 
is completed (transmitted or received), if there was an error 
and if there is a Data Set Change. it also monitors the states 
of INTRO, DROO and DROI. 
The SR register indicates if an error is recognized by IR, 
what type of error. It also monitors the mgdem control 
signalslg indicato_r_'(RI)', Carrier Detect (CD), Data Set 
Ready (ose) and IT/1_is_c in. 
Furthermore, the SR register monitors if the Receiver is 
idle, and also if in receive mode if the user has programmed 
the Receiver Character Length to be 8 bits per character, this 
register indicates the number of residual bits received. For 
more detailed information, see Register Formats. 


Read/Wrlte Control Of CPU Interface Registers 
These registers are directly accessible from the CPU bus 
(D—7-E by a read and/or write operation by the CPU. 
The CPU must set up the v|_19ss ieter address (AE- 
T0), Chip Select (C-S), Write Enable (WE) or Read Enable 


(_R_E_) before each data bus transfer operation. 
During a write operation, the falling edge ofWE will initiate 
a VL1935 write cycle. The addressed register will then be 
loaded with the content of the Data_Bus (D7-D During a 
read operation, the falling edge of RE will initiate a VL1935 
read cycle. The addressed register will then place its content 
onto the Data Bus (If-IT). The read/write operation is oom- 
pleted, when CS or RE/WE is brought high. 
See Read/Write Timing diagram for more detailed infor- 
mation. 
For read and write operation, the CR1-3 registers normal- 
ly need no external clock. After reset of CR1-3, TOclock is 
required. The AR and THR registers need no external clock, 
and can only be written into. The RHR, IR and SR registers 
need Transmit Clock (TC) or Receive Clock (RC) to set 
various bits, and are read-only. 
All these registers will get initialized by a Master Reset. A 
read operation of RHR resets the DROI. A write operation 
to THR, resets the DROO. A read operation of IR, resets IR 
bits 0 and 3-7. A read operation of SR, resets SR bits 0-2. 
For addressing and external clocks needed, see TABLE 2. 


A more detailed description is shown in Figure 6 of each bit 
location. It should be known, that because the Data Bus 
Lines (D*'7-'II)_()) have inverted logic, a logic 1, asserted means 
low state. Also, a modem control signal which is inverted 
(example TR), is in on-state (asserted) when low. 
. 
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TABLE 2. 
DEVICE ADDRESS CODES 
VL1935 


E 
“T2 
'/T1 
T5 
Read 
Write 
External Clock 


If-I"I_I_I_I_ 
XF'I-IIII 
XIII-r-II 
><r- 
f"II"I 


CR1 
CR2 
CR3 
RHR 
I 
5 
SR 
X 


CR1 
None‘ 
CR2 
None‘ 
CR3 
None’ 
AR 
eHR=:. 
AR=None 
THR 
|R=TC. 
THR=None 
- 
SRO-3=R—C. 
SR4-7=None. 
x 


L = V|L at pins 
H = V||-I at pins 
X = Don't care 


REGISTER FORMATS 
Below shows a short form register format. 


BIT '——> 
17 
16 
15 
14 
13 
12 
11 
10 


A T 
A T 
TCL 
TCL 
ote 
MISC 
Cm 
REC 
TRAN 
ut 


21 
26 
2s 
24 
23 
22 
21 
20 
ext 
ADDR 
ext 
ecl 
RCL 
LOOP 
seu= 
Auto 
coutn come ADDR 
test 
FLAG 
CR2 


TRES 
tees 
tees 
useo 
useo 
useo 
useo 
CR3 


7 
6 
5 
4 
3 
2 
1 
0 


7 
6 
5 
4 
3 
2 
1 
O 


1 
6 
s 
4 
s 
2 
- 1 
0 


REOM 
xwt 
xmt 
neon 
W, 
econoecou osc 
onoo mteo 
W/no eneoe 
w/ 
w/ 
In 
neon 
N0 
uwoen 
ennoe 
nun 


7 
6 
5 
4 
3 
2 
1 
0 


7 
6 
5. 
4 
3 
2 
1 
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AF/IF 
CRC 
CD 
MISC 
REC. 
QR 
RFLES 
RHES 
SH 


IN 
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RRES 2 
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FIGURE 6_. 
VL1935 BIT ASSIGNMENTS 
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Control Register 1 (CR1) 
When initiating a transmit/receive operation, this should be 
the last register programmed. 
Miscellaneous Output (CR10) 
This bit controls the Mis- 
cellaneous Output signal to the data set. When CR10 is a 
logical 0, Misc Out is off, when it is a logical 1, Misc Out 
is on. 


*2.5 TC clock cycles are required 
after a Master Reset to be able to 
read and write. 


DTR Command (CR11) 
This bit controls the data Ter- 
minal Ready (_D-W) signal to the data set. When CR11 is a 
logical 0,_CTlR is off. When CR11 is a logical 1,'D—TR is on. 
When the Self-Test mode is selected,'lTR signal is forced 
to an off state. 
Transmitter Character Length (CR13, 12) 
These bits 
control the transmitted I-field data character length. The 
data character may be 5, 6, 7 or 8 bits long. 


TABLE 3. 
TRANSMITTER CHARACTER LENGTH 


Bits Per 
CR13 (TCL1) 
CR12 (TCLO) 
Character 


O 
O 
8 


O 
1 
7 


—L-L 
-o 
mo: 


Transmitter Commands (CR15, 14) 
These bits control 
the transmission of DATA (A-field, C-field and I-field), ABORT, 
FLAG, and FCS (FCS plus FLAG). When these commands 
are programmed, the previous command currently still in 
progress, will complete the transmission of its character. 
When this is done, a new character generated by this new 
command, will be transmitted. 


CR 14, 15 can be programmed as follows: 
A. If DATA is programmed, the new character to be transmit- 
ted will be the character loaded (or still to be loaded) in the 
THR REGISTER. 
B. If ABORT is programmed, the new character will be eight 
logical 1's. 
C. If FLAG is programmed, the new character will be 
01111110. 
D. If FCS is programmed, the new character which will be 
transmitted consists of the residual byte (which was auto- 
matically transferred to the XMIT REGISTER, provided 
that CR30-32 and are set correctly), followed by the 16-bit 
content of the FCS XMIT REGISTER and the FLAG. 


One serial bit ahead of this new character (for FCS com- 
mand the FLAG character), the CPU is signalled by DROO or 
INTRO that the VL1935 is again ready to receive a new com- 
mand. DROO is asserted by a DATA command and INTRO 
(XMIT OPCOM) is asserted by an ABORT, FLAG or FCS com- 
mand. 
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TABLE 4. 
TRANSMITTER COMMANDS 
VL1935 


CR15 (TC1) 
CR14 (TCO) 
Command 
Character/s Transmitted 
Si nal to CPU 


—*-4~OO 
.-50-50 


DATA 
ABORT 
FLAG 
FCS 


Content of THR 
DROO 
1111 1111 
INTRO 
0111 1110 
INTRO 
FCS + 01111110 
INTRO 


In the case of the DATA command the user has two 
choices; 1. Change the command. 2. Keep the DATA com- 
mand and load a new character into the THR register. For 
more information, please see the Transmission Timing dia- 
gram, Figure 7. See Table 4 for programming information. 


Activate Transmitter (CR 16) 
This bit when set, enables 
the transmitter and setsRT_S' signal. If in SDLC Loop Mode 
(CR22 = set), the transmitter waits for a Go-Ahead pattem 
before the transmitter is enabled. 
Activate Receiver (CR 17) 
This bit when set activates 
the receiver, which begins shifting in frames one character 
at a time into RR register for inspection. 


CONTROL REGISTER 2 (CR2) 
Auto Flag (CR20) 
When set, Flags (without lNTROs) will 
be continuously transmitted in between frames, when other- 
wise the transmitter would be in idle state. 
Self-Test Mode (CR21) 
When set, the Transmitter Data 
Output is internally connected to the Receiver Data input 
circuitry. The, modem control output signals are deactivated 
(off state). The modem control input signals are intemally 
activated. This mode allows off-line. diagnostic. 
SDLC Loop Mode (CR22) 
When set, the VL1935 is 
conditioned to operate in an SDLC Loop Data Link system 
(see SDLC Loop Mode). 
Receiver Character Length (CR24, 23) 
These bits in- 
dicate to the receiver how many bits per character there are 
to assemble for the I-field. The I-field characters may be 5, 
6, 7 or 8 bits long. The unused bits read from RHR will be 
logical 0. 


TABLE 5. 
RECEIVER CHARACTER LENGTH 


CR24 
CR23 
Bits Per 
(RCL1) 
(RCLO) 
Character 


0 
0 
-8 
0 
1 
7 


-L—A 
-o 
mo: 


TABLE 6. 
TRANSMITTER RESIDUAL COMMANDS 


Extended Address (CR25) 
When set, this bit indicates 
to the receiver that there is more than one address character 
in the A-field. The receiver will expect another address char- 
acter if the LSB in the current address character is a logical 0." 
The purpose of this bit: if a non-8-bit field character length is 
expected, the DROls will get out of synchronization if the 
VL1935 does not know exactly when the I-field will start. Not 
used in transmit mode. 
Address Compare (CR26) 
When set, the first address 
character will be inspected in the Address Comparator. if 
there is a match with the AR register, or if the address com- 
pared is a Global Address (eight 1's) the frame is considered 
valid, causing DRO|s to be generated. Otherwise, the re- 
ceiver does not react, and will continue comparing for a new 
valid address. If not set, all frames are considered valid. 
Extended Control (CR27) 
When set, indicates that 
there are two control characters per name. if not set, there is 
only one control character per frame. The purpose of this bit: 
If a non-8-bit I-field character length is to be received, the 
DRO|s will getout of synchronization if the VL1935 does not 
know when the I-field will start. Not used in transmit mode. 


CONTROL REGISTER (CR3) 
Transmit Residual Character Length (CR32, 31, 30) 
(Table 6) These bits inform the transmitter what bit-length the 
residual character will be. if no residual character is to be 
sent, these bits must be set to logical 0. (See Transmitter 
Commands). 
Unused (CR33-37) 
These bits are not used, and are 
always a logical O. 


INTERRUPT REGISTER (IR) 
This register contains the information why an interrupt 
INTRO was generated. An IR register read operation, will 
reset bits 0, and 3-7. The Transmitter clock must be active to 
generate an interrupt. 


Loading the THR register, will reset DROO (bit 1). Reading 
the RHR register, will reset DROI (bit 2). A new interrupt will 
occur if one is pending. 


CR32 
CR31 
CR30 
(TRES 2) 
(TRES 1) 
(TRES 0) 
Residual Char. Length 


0 
0 
0 
0 
O 


-A-Loo-A-L 
135 


No residual char. sent 


1 
1 bit 
2 bits 
3 bits 
4 bits 
5 bits 
6 bits 
7 bits 
-L@_A@_A@ 
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TABLE 7. 
DATA SET CHANGE PROGRAMMING 
VL1935 


CD1 
interrupting edge of'C_-D 
interrupting edge of 


LO 
LO 
Rising and falling 
LO 
HI 
Falling 
HI 
LO 
Rising 
Hi 
Hi 
None 


If a new interrupt is generated while the CPU is reading 
the IR register, this new interrupt will set the respective bit 
in the IR register one bit time later (this to avoid losing any 
interrupt). The status of bits 3-7 will accumulate until the IR 
register is read by CPU. 
INTRO (IRO) 
When set, indicates an interrupt and that 
there are one or more bits set in positions 3 through 7 of this 
register. This bit is a mirror image of INTRO signal (pin 6). 
When pin 6 (INTRO) is not used for pending interrupts 
information and only the IR register is read to obtain the 
status of the interrupt bits (polling method), a minimum of 
two (2) bits times must be allowed between IR registers 
“read’s” to insure an orderly flow of pending interrupts. 


DROO (IR1) 
When set, indicates a Data request output. 
This bit is a mirror image of DROO signal (pin 18). 


DROI (iR2) 
When set, indicates a Data Request input. 
This bit is a mirror image of DROI signal (pin 19). 
Data Set Change (IR3) When set, indicates a change of 
state of the Data Set (D_iCOlmU_L28IIOi'l Equipment). This 
i_§_a change of state of DSR, CD or RI. The type of change of 
CD and RI thalhiswill re_a£t_t£,_is programmed by use of 
input signals CD1/CDO and RI1/RIO (Table 7). 


XMIT 
Operation 
Complete 
with 
Underrun 
Error 
(IR4) 
When set, indicates that the transmitter command 
has been completed and there was an Underrun error. An 
Underrun error occurs when the Data Request Output 
(DROO) is set, but THR register is not loaded in time. 
XMIT Operation with No Error (iR5) 
When set, indi- 
cates that the transmitter command has been completed and 
there was no error. 


Received End of Message With Errors (lR6) When set, 
indicates that a Received End of Message is detected, and 
there was an error. Errors include CRC, Overrun, invalid 
Frame and Aborted Frame. 
The SR Register bits 0-2 will indicate the exact type of 
error. 
Received End of Message With No Error (IR7) 
When 
set, indicates that a Received End of Message is detected, 
and there was no error. The "IR7 bit is the inverse of the 
REOM output signal. 


STATUS REGISTER (SR) 
This register contains the status of the receiver and some 
modem control signals. it also indicates (if REOM w/Errors) 
exactly what type of errors. If the Receiver Character Length 
is 8 bits, this register indicates the amount of Residual bits 
that was received. A read operation will reset bits 0-2. 


Received Error/Received Residual Character Length 
(SR 2-0) if REOM w/NO ERROR (IR7) is set, these bits (SR 2- 
0), indicate the number of residual bits received (Table 8). 


LO 
LO 
Rising and falling 
LO 
HI 
Failing 
HI 
LO 
Rising 
HI 
Hi 
None 


lf REOM WITH ERROR (IR 6) is set, these bits indicate the 
type of error that occurred (Table 9). 


TABLE 8. 


-§CDI\J-*QU'l-§COI\)—*QO')U'1-§(DI\J—*Q\lO)U1J>(AJI\) 
---ooooc>o----o-----oo-----ooooolltn 


CHAR. 
RES. 
LENGTH 
BITS 
8 
0 
Bits/Char. 
1 


7 
Bits/Char. 


6 
Bits/Char. 


5 
Bits/Char. 


TABLE 9. 


Bit Set 
Error 


SRO 
CRC 
SR1 
Overrun 
SR2 
Aborted or 
invalid frame 


Receiver Idle (SR 3) 
When set, indicates that the re- 
ceiver is currently IDLE. 
Miscellaneous input (SR4) 
This is a mirror image of 
MISC IN signal. When this signal is set, SR4 bit is set. 
Data Set Ready (SR5) 
This is mirror image of E_BT sig- 
nal. When this signal is set, SR5 bit is set. 
Carrier Detect (SR6) 
This is a mirror image of CD signal. 
When this signal is set, SR6 bit is set. 
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Ring indicator (SR7) 
This is the inverse of the RI signal. 
When SR7 bit is set, a ringing signal has been received on 
the communication channel. 
TRANSMITTER OPERATION 
Prior to this operation, the programmable inputs and the 
transmit mode related register bits need to be programmed 
according to the user's specific data communications envi- 
ronment. The last bit to be set is always the ACT TRAN 
(CR16) bit. 
Before this, the INTRO has to be cleared, which can be 
done by reading the IR register. For more detailed information 
how to program the VL1935 see Programming. 
As an example of how to program the VL1935 let's 
assume a 24-bit information is to be transmitted. The I-field 
would then consist of three 8-bit characters with no residual 
bits. CR3 should then be 00 (Hex). 


Bits CR23-CR27 are for reception only (see Receiver 
Operation). The last register to be programmed is CR1. if 
MISC OUT is not used, this may be ignored. if a modem is 
used, DTR (CR11) is to be set. CR13 and CR12 should be 
logical 0's (8-bit char. length). CR15 and CR14 should be 
logical 0's (Data Command). ACT TRAN (CR16) bit _is to be 
set. The ACT REC (CR17) is for reception only. 


Q11-i 
The DTR bit, when set, activates the DTR signal, indica- 
ting to the modem to prepare for communication. When the 
modem is ready, it sends back a Data Set Ready (TSR) to the 
VL1935 . This causes the DSC (IR3) bit to set, which in turn 
activates INTRO. The IR register is now read. Simultane- 
ously, when the ACT TRAN (CR16) bit is set, this activates the 
Request to Send (T) signal, instructing the modem to enter 
into transmit mode. When the modem is ready to transmit 
data, it responds by activating the Clear to Send (CTS) signal. 
The VL1935 is now conditioned to transmit. Now DROO 
gets, set, indicating to the CPU (or DMA) to load the first char- 
acter (Address) into the THR. When this is done, DROO will 
reset. As soon as the VL1935 is ready to be loaded with the 
next character to be transmitted, DROO is again set. When 
the THR register is again loaded with a character, DROO will 
again reset. 


This same sequence continues until the last I-field char- 
acter to be transmitted is loaded into the THR. if CRC check- 
ing is to be used, the next time when DROO is set, an FCS 
command has to be programmed. This is accomplished bv 
either setting CR15, 14 to both logical 1's or by activating the 
§)B signal. 
At the end of the FCS being transmitted, INTRO will set 
indicating XMIT Operation Complete. The IR register is to be 
read to find out whether the frame was sent with or without 
error. Also the FCS Command which was used as described 
above has to be changed. if CR15, lwere set, these have 
to be reset (to Data Command), or if EOB was activated, this 
signal has to be deactivated. At this same time, the ACT 
TRAN bit is allowed to be reset, causing the TD output to go 
idle after the end Flag is sent. If the ACT TRAN bit is kept 
set, continuous Flags will be sent following the FCS. 
If a new frame is to be sent right after this first frame, only 
one Flag is needed in between frames, meaning the frames 
have one common Flag character. In this case, the second 
frame Address character may be loaded at the same time 
the FCS command is programmed dun'ng the first frame. 


VL1935 


Also, the ACT TRAN bit should be kept set in between 
frames. Every time DROO gets set, the user must load the 
THR register before the last loaded character only has 1.5 
bits left to be transmitted. in other words, when DROO gets 
set, the user may wait (if 8-bit characters) up to 7.5 serial 
data bits before loading the THR. If THR is not loaded within 
this time, an Underrun error will occur. 
If Auto Flag is not selected (CR20 == logical 0) the sequence 
will be a little different than described below. When the first 
DROO is set, and after the Address character is loaded into 
THR, a Flag command is also programmed (CR15, 14 = 10). 
This will set an interrupt (INTRO), which indicates that the 
IR register must be read. Now, the Data Command is repro- 
grammed (CR15, 14 =00). 
For more information, see Transmission Timing diagram. 


ABORT CONDITIONS 
The function of prematurely terminating a data-link is 
called an “Abort.” The transmitting station aborts by send- 
ing eight consecutive 1’s. Unintentional Abort caused by 
1's in the A-C- or I-field is prevented by zero insertion. inten- 
tional Abort may be sent by programming an Abort com- 
mand. Abort will also be sent in the case where THR is not 
loaded in time or FCS command is not programmed in time 
(=underrun). This means that afte[_th_e DROO is set, to 
avoid Abort; THR must be loaded, EOB activated or FCS 
command programmed before there is only 1.5 bits left of 
the last character to be transmitted. 
if this is not done, INTRO (XMIT OPCOM w/underrun) is 
set and Aborts are transmitted until, either the command is 
changed or the THR is loaded. if in this same case, Auto 
Flag was programmed, one Abort (with INTRO) would be 
generated, and thereafter continuous Flags (with no lNTROs) 
will be sent. 


RECEIVER OPERATION 
Prior to this operation, the programmable inputs and the 
receive mode related register bits have to be programmed 
according to the user's specific data communication environ- 
ment. Also, the INTRO has to be cleared. The last bit to be 
set is always the ACT REC (CR17) bit. 


For more detailed information how to program the VL1935 
see Programming. As an example, let's assume a 26-bit infor- 
mation is to be received, and the I-field is made up by 8-bit 
characters. The CR3 register is only for transmit mode, and 
may be ignored here. CR20 and CR 12-16 bits are also for 
transmit mode only, and therefore may also be ignored. CR21 
and CR22 are to be logical 0s (no Self-Test and no SDLC 
Loop Mode). CR24, 23 are to be logical 0's (8-bit character I- 
field). if only one A-field and one C-field character is 
expected, and this VL1935 has a specific address, CR25 
should be a logical 0, CR26 should be a 1, and CR27 should 
be a 0. The address to which the A-field should compare 
should be loaded into the AR register. 
The status of the modem is monitored by the SR register, 
and it may be useful to read it at this time. CR1 is loaded as 
the last register. CR10 (Misc in) bit is optionable to the user. 
CR11 (DTR) is to be set if modem is used. CR17 (ACT REC) 
is now set, starting the input of frame characters into the 
Receiver Register (RR). When a Flag is detected, the next 
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8-bit character (address-character), when received, is com- 
pared to the character in the AR register. if these match, or 
if the received character is a Global address, this frame is 
valid, and the DROI gets set. If the Address Comparator 
(CR26) bit is not set, all frames would be considered valid 
and generate DROls. When the RHR register is read, DROI 
will be reset. All characters in a valid frame which are input 
into the RR register will set DROI, and every time RHR is 
read by the CPU, DROI will be reset. 
During reception, thereceiver also performs a CRC cai- 
culation on the incoming data. When the end Flag is re- 
ceived, INTRO will get set, indicating Received End of 
Message. if the reception is completed with no error, IR7 
(REOM w/no Error) bit will be set. When 8-bit characters are 
received SR 0-2 bits indicate the number of residual bits, in 
this case two. if lR6 (REOM wlError) was set, SR 0-2 bits 
indicate the type of errors (see Receiver Error indication). 
When all characters including the A-field and the FCS- 
fieid are read, and when the REOM interrupt is recognized, 
it is up to the user to disassemble these mentioned charac- 
ters from the received data. if non-8-bit characters are re- 
ceived, the amount of residual bits have to be calculated by 
the CPU after masking out the part of the ending Flag 
showing up in the last read character. 
After end of frame, the receiver begins searching for a 
new frame. 


(For more information, see Figure 8.) 


RECEIVER ERROR INDICATION 
When a frame is received, and REOM w/Error (lR6) is set, 
the type of error is indicated by the SR bits 0-2. 


TABLE 10. 


VL1935 


CRC Error (SRO) 
if the CRC calculation performed on 
the incoming data does not equal to FOB8 (HEX), this bit will 
be set. 
Overrun Error (SR1) 
After DROI is set, if the RHR is not 
read within one character minus one bit time, this bit will be 
set. 
- 
' 
Aborted or invalid Frame Error (SR2) if the frame is 
aborted or if in a frame the number of bits between flags are 
less than the required minimum (see Table 10), this bit will be 
set. 


NOTES 
1. TC-command—lf two or more contiguous ABORTS or 
FLAGS are executed, the ACT TRAN (CR16) bit has_to be 
reset before DATA-command can be executed. 


2. Master Reset (MR)—Needs no clock during activation of 
MR. However, 2.5 clock cycles are required to reset the 
VL1935 after the falling edge of MR. 


3. IR-register—lmmediately when IR register is read, bit 0 
will reset. Bits 3-7 are reset one bit time later. 


4. SR-register—Bits 0-2 are reset one bit time after SR reg- 
ister is read. 


5. SDLC Loop mode—Go-ahead pattern may be sent by 
either sending IDLE or ABORT after Flag. 


6. %and'RC clocks are completely independent of each 
other. 


7. it is recommended to verify that the INTRO signal (pin 6) 
is set prior to reading the IR register. 


8. End Of Block (EOB) — Minimum activated time must be 
one (1) character time. it can be activated indefinitely 
using IDDLE or AUTO FLAG (CR20). 
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FIGURE 7. 
VL1935 TRANSMISSION TIMING DIAGRAM 
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FIGURE 8. 
VL1935 RECEPTION TIMING DIAGRAM 
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SPECIFICATIONS 
I 
ELECTRICAL CHARACTERISTICS 
Absolute Maximum Ratings 
Storage Temperature 
—55°C to +125°C (plastic package) 
Storage Temperature 
-65°C to +150°C (ceramic package) 
Voltage on any pin 
-0.3 to +7.0 V 
with respect to GND (V55) 
Power Dissipation 
1W 


DC Characteristics 
TA = 0°C to +70° 
V33=0IV,VCC=+5i0.25V 


TABLE 11. 
VL1935 DC CHARACTERISTICS 


$Y'"b°' 
@@@ 
°°"°"‘°"=‘- 


10 
pA 
VIN = v¢¢ 
VOUT = vcc or Vss 
|L| 
Input Leakage 
ILQ 
Output Leakage 
10 
pA 
V|H 
Input High Voltage 
V 
V||_ 
Input Low Voltage 
0.8 
V 
VQH 
Output High Voltage 
V 
VQL 
Output Low Voltage 
0.4 
V 
ICC 
Supply Current 
70 
210 
ma 


AC Characteristics 
TA = 0°CIO +70° 
V53=0V,V(_jC=+5iO.25V 


TABLE 12. 
VL1935 AC CHARACTERISTICS 


AII Inputs 
_ 
: 
-‘IOOpA 
IO 
IQ = 
1.6mA 


' 
I 
m 
R 
_ 
_'i 
i 
— 
-10 
-11 
-12 


71' J 
' 
I331 
| 
' 
I 
I 
1'3" 
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Symbol 
Parameter 
Min 
Max 
Min 
Max 
Min 
Max 
Min 
Conditions 


READ & WRITE (Fig. 9, 10) 
TA3 
Address Set-Up 
20 
20 
20 
TAH 
Address Hold 
20 
20 
20 
TCSS 
Chip Select Set-up 
20 
20 
20 
TCSH 
Chip Select Hold 
20 
20 
20 
READ (Fig. 9) 
- 
TQED 
Data Delay from Asserted 
I 
315 
290 
265 
Date Valid from R_E Deassertedri 
0 
140 
0 
140 
0 
140 
DROI Reset Delay 
' 
280 
280 
280 
T|NTRQ 
INTRO Reset Delay 
280 
280 
280 


Tov 
TDRQIR 


TRE 
Re Pulse width 
325 
300 
275 
WRITE (Fig. 10) 
T95 
Data Set-up 
' 
T 200 
180 
. 
160 
TDH 
Data HOId 
l 
20 
20 
20 
TDRQQ 
DROO Reset Delay 
330 
330 
330 
TWE 
we Pulse width 
200 
180 
160 
TRANSMlT& RECEIVE (Fig.11) 
' 
TRD3 
Receive Data Set Up 
150 
150 
150 
TRDH 
Receive Data Hold 
I 150 
150 
150 
TTDQ 
Transmit Data Out Delay 
125 
\ 
125 
125 


CLOCK 
1xF¢ 
1X Clock 
.5 
1.0 
1.5 


32xFC 
32X Clock 
1.0 
1.5 
2.0 


RISE a. FALL (Fig. 12) 
TR 
Rise Time 
20 
20 
Ti: 
Fall Time 
20 
_2o 


NOTE: All A.C. Timing Measurements made at 0.8 V and 2.0 V. 


__ 
.1 
Ii 
E 


20 
20 
20 
20 


0 


250 


140 
20 


140 


‘I50 
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240 


1 40 
280 
280 


330 


125 


2.0 


2.5 


20 
20 
20 
20 


at 50% duty 
cycle 
at 50% duty 
cycle 


See figure 1 
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FIGURE 9. 
VL1935 READ TIMING DIAGRAM 
FIGURE 10. 
VL1935 WRITE TIMING DIAGRAM 
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FIGURE 11 . 
RECEIVER AND TRANSMITTER TIMING 
FIGURE 12. 
VL1935 RISE AND FALL TIMING DIAGRAM 
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FIGURE 13. 
VL1935 TRANSMITTER FLOW CHART 
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FIGURE 14. 
VL1935 RECEIVER FLOW CHART 
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FEATURES 
~16x16 parallel multiplication and 
product accumulation 


- High-speed multiply-accumulate time 
-65 ns, typical 
-90 ns, max 


- CMOS silicon-gate technology 


- Single 5 V supply 


~ Low poW8!’ 
-0.2, W typical 


~ Standard 'lTL-compatible I/O levels 


- Performs double-precision subtrac- 
tion, addition, and multiplication, 
including rounding control 


- Pin-for-pin functional replacement for 
WTL1 0 
TDO1 0 
10, WTL2010, 
10J, LMA1010, and 
AMD29510 


~ 64-pin ceramic and plastic DIP 


~ 68-terminal plastic leaded chip 
carrier (PLCC) 


VL201 0 


16 X 16 PARALLEL MULTIPLIER-ACCUMULATOR 


DESCRIPTION 
The VL2010 is a 16 x 16 parallel multi- 
plier-accumulator (MAC) that offers 
ultra-low power consumption and very 
high performance. High performance is 
achieved through the use of the 
efficient Booth's algorithm and 
advanced VLSI processing technology. 


The VL2010, under control of the ACC 
input, performs either the multiply only, 
or the multiply-accumulate function. ln 
either mode, input data X and Y can 
be specified as two's complement or 
unsigned magnitude. Input data 
representation is selectable via the 
input control line, TC. In the multiply- 
only mode, extended product (XTP) 
data is sign-extended or set to zero for 
two's complement and unsigned- 
magnitude arithmetic, respectively. An 
RND control is available for rounding 
up the most signicant product (MSP) 
and extended product (XTP) data. In 
the multiply-accumulate mode, the 
double-precision accumulated answer 
is rounded back to single-precision or 
single-precision plus XTP bits. 


The VL2010 architecture includes input 
and output data registers, as well as 
three-state output data buses with in- 
dependent, non-registered control. 
Time-multiplexing is used for the 
common least significant product (LSP) 
_ald_lr]Lu_t_Data flu/O lines. lnput lines 
TSX, TSM, and TSL, respectively, 
control the outputs of the XTP, MSP, 
and LSP registers. 


In the multiply-accumulate mode (ACC 
active), output data can be added to or 
subtracted from the last product. When 
SUB is also active, subtraction occurs. 
Otherwise, addition is performed. 


The VL2010 can be efficiently applied 
in a variety of digital signal processing 
functions, including digital filtering 
(recursive, non-recursive, wave) and 
FFT processing (complex multiplica- 
tion, butterfly computation). In addition, 
the VL2010 can be employed effec- 
tively in upgrading the computational 
capability of mini- and microcomputer 
systems. 
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PIN DIAGRAM 


Y1 ,P1 


Y2,P2 


Y3,P3 


Y4,P4 


Y5,P5 
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Y7,P7 
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GND 
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PIN DESCRIPTIONS 
X 
Data Input 
X is a 16-bit input. Data bits are loaded 
on the rising edge of CLKX. 
Y/LSP 
Data Input! 
Data Output 
These pins share functions between Y 
(16-bit data input) and LSP (least 
significant product output). Input data 
bits are loaded on the rising edge of 
CLKY. Output LSP data bits are 
available following the rising edge of 
CLKP. 


MSP 
Data Output 
The 16-bit most-significant product 
output. MSP data is available following 


CLKX, CLKY 
lnputClocks 
These X and Y data input register 
clocks are active on their rising edges. 


ACC 
Accumulate 
A HIGH level input permits the 
contents of the LSP, MSP, and XTP 
registers to be added to the multiplier 
output. A LOW level input allows 
multiplication only. The ACC signal is 
loaded on the rising edge of either 
CLKX or CLKY, and must be valid for 
the entire duration of input data. 


SUB 
Subtract 
When ACC and SUB are both HIGH, 
the contents of the output register are 
subtracted from the last product 
generated, and the difference is stored 
back into the output registers at the 
rising edge of the next CLKP. When 
ACC is HIGH and SUB is LOW, 
addition instead of subtraction is 
performed. The SUB signal is loaded 
into the SUB register at the rising edge 
of either CLKX or CLKY. 


The SUB signal must be valid over the 
same period that the input data is 
valid. When ACC is LOW, SUB is a 
"Don't Care” pin. 


VL2010 


PIN DIAGRAM 
RND 
Round 
A HIGH-level input causes a "1" to be 
added to the most significant bit of the 
LSP to round up MSP and XTP data. 
RND is loaded on the rising edge of 
X3 I 4 
either CLKX or CLKY and must be 
X2 I 5 
valid for the duration of the input data. 
X1 I 6 
X0 I 7 
8 
Tc 
Y0,P0 I 
Two'sComplement/ Unsigned Magnl- 
Y1 ,P1 - 9 
I"d° 
Y2,P2 I 10 
11 
12 


X61 
X52 
X43 


A HIGH-level input defines X and Y as 
Y3,P3 I 
two's complement data, while a LOW 
Y4_P4 I 
level defines the input data as un- 
Y5,P5 I 13 
signed magnitude. As with ACC, SUB, 
Y6,P6 I '4 
and RND, TC is loaded at the rising 
Y7,P7 I '5 
edge of either CLKX or CLKY and 
GND I ‘6 
must be valid for the duration of the 
Y8,P8 I 
input data. 
Y9.P9 I 
___i__ 
Y10,P10 I '9 
TSX,TSM,TSL 
Y11,P11 I 20 
3-stateOutputControls 
Y12,P12 I 21 
The LSP, MSP, or XTP output buffers 
Y13,P13 I 22 
are at high-impedance_(Q1tput 
Y14,P14 I 23 
disabled) whenTSI., TSM, orTSX, 
Y15,P15 I 24 
respectively, is HIGH. These are 
P16 I 25 
direct, nonregistered control signals. 
P17 - 


28 
LIE output mg: are enabled when 
P19 - 
'rs|., 'l'§l€l, or TSX is LOW. 
P19 " 
P20 I 29 
P21 I 30 
P22 I 31 
P23 I 32 
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P 
Hl Z 
P 
PL 
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Hf 
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P 


1 
PL 
P 
Notes: 
Hi-Z - Output buffers at high impedance (Output disabled). 
Q=- Output buffers at low impedance. Contents of output registers will 
to output pins. 


—L_L¢L—L_L 
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64 I X7 
63 X3 
62 X9 
61 I X10 
50 I X11 
59 I X12 
58 I X13 
57 I X14 
56 I Ei 
55 I TSL 
54 I RND 
53 I SUB 
52 I ACC 
51 - CLKX 
50 I CLKY 
49 — VCC 
48 Q 
47T$x 
46 - PREL 
45 - TSM 
44 I CLKP 
43 I P34 
42 I P33 
41 I P32 
40 I P31 
39 I P30 
38 I P29 
37 I P23 
36 I P27 
35 I P25 
34 I P25 
33 I P24 


LSP 
O 
Hi-Z 
O 
Hi-Z 
O 
Hi-Z 
Q 
Hi-Z 
Hi-Z 
PL 
Hi-Z 
PL 
Hi-Z 
PL 
Hi-Z 
PL 


be transferred 


PL- Output buffers at high impedance, or output disabled. Preload data supplied 
externally will be loaded into the output register at the rising edge of C 
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DATA FORMATS 
FRACTIONAL TWO'S COMPLEMENT 


BIT 
13 
‘II? 
0 
INPUT 
VALUE 
sew 
2- 
‘ggg 2»- 
‘II-I 
"AWE 
2 1- I 
*5 
‘T 
I?’ 
1:... 
av.._ 
,,,,,,.,,, 
Br 
E’ l 
16 
VALUE 
IIL 
‘III 2-“ 
LSP 
B" 
15 
El. YIIII 
0 
VALUE 
‘IE1 as 
Notes: 
1. The value of the input sign bits is -2°. 


E -1 


G)Z 


7 


'\? 
7*? 
|\P 
“Po 


2. The format shown uses a two's complement fractional notation. Note that the location of the binary point signifying the 
separation of the integer and fractional fields is just after the sign, between the sign (-2°) and and the next most significant bit 
for the multiplier inputs (-2‘). This scheme is carried over to the output format, except that an extended significance to the 
integer field is provided to extend the utility of the accumulator. Consistent with the input notation, the output binary point is 
located between the -2° and the -2‘ bit positions. 


The location of the binary point is arbitrary, as long as one is consistent with both input and output formats. One can consider 
the numberfield entirely integer, i.e., with the binary point just to the right of the least significant bit for input, product, and 
accumulated sum. 


3. When nonaccumulating, all first four bits (P34 to P31) will indicate the sign of the product. The P30 term will also indicate 
the sign, except for the one exceptional case when multiplying -1 X -1. Note that, with the additional significant bits available 
on this multiplier, -1 X -1 is a valid operation yielding +1 product. 


4. Whether accumulating the sum of products or doing single products, there is no change in format. However, the three 
additional most significant bits (the guard bits) are provided to allow valid summation beyond that available for a single 
multiplication product. For further clarification, no difference exists between this organization and one which would have the 
product accumul;ation off-chip in a separate 18-bit adder. Taking the sign at the ost siginificant bit position guarantees that the 
largest number field will be used. ln operation, the sign will be extended into the lesser significant bit positions when the 
accumulated sum only occupies a right-hand portrion of the accumulator. As an example, whenthe sum only occupies the 
least three bit positions, then the sign will be extended through the 16 most significant positions. 
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AC CHARACTERISTICS 
TA = 0 ~c to 70 sc, vcc = 5 v :l: .25 v 


Parameter 
Symbol 


tD 
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T 
‘Oi 
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Multiply Accumulate Time 


Clock Pulse Width 


Input Register Setup Time 
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BI‘ 
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ma 
Condltlons 
an 
Load 1 (Figure 3) 
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FIGURE 1. INPUT EQUIVALENT CIRCUIT 


FIGURE 2. OUTPUT CIRCUIT 


—I 


—I 


FIGURE 3. TEST LOAD FOR DELAY MEASUREMENT 


FROM 
OUTPUT 
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VCC 
I 


VL201 0 


FIGURE 4. TEST LOAD FOR 3-STATE DELAY 


FROM 
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0V, 
40 PF 
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FIGURE 5. SUPPLY CURRENT VS OPERATING 
FREQUENCY 
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FIGURE 6. MULTIPLY-ACCUMULATE TIME VS AMBIENT 
TEMPERATURE 
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ABSOLUTE MAXIMUM RATINGS 
Supply Voltage 
-0.5 to 7.0 V 
Input Voltage 
-0.5 to 7.0 V 
Output Voltage 
-0.5 to 7.0 V 
Operating Temperature 
0 °C to 70°C 
Storage Temperature 
-65 C to 150 C 
Lead Temperature (10 Sec.) 
300 C 
Maximumdunction Temp. 
175 C 


DC CHARACTERISTICS 
TA = 0 "c to 70 =>c, vcc: sv ¢.2s 


Symbol 
Parameter 


VIH 


VIL 


VOH 


VOL 


IIH 


IIL 


IOH 


IOL 


ICC 


ICC/F 
Supply Current Increase/MHz 


CAPACITANCE TA = 0 sc to 10 sc 


Symbol 
Parameter 
T 
Condltlons 


Cl 


CO 


U1 


333<>>> 


High level Input Voltage 


Low Level ln ut Volta e 


level Output Vo 


Low Level Out ut Volta e 


High level Input Current 


Low Level Input Current 


High level Output Current 


Low level Output Current 


Supply Current at DC 


Clocks 
Data, Latched Controls 
Input Capacitance 


Output Capacitance 


Stresses above those listed under 
"Absolute Maximum Ratings” may 
cause permanent damage to the 
device. These are stress ratings only. 
Functional operation of this device at 
these or any other conditions above 


-I 
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ts 


01 


Unlatched Controls 


‘O 
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‘OT 


151 


as52 


.4C 


'0 I 
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those listed on the operational sections 
of this specification is not implied and 
exposure to absolute maximum ratings 
conditions for extended periods may 
affect device reliability. 


Condltlons 


VCC-=Min; IOH-0.4 mA 


VCC-Min; IOL-4.0 mA 


VCC-Max; VIH=2.4 V 


VCC-=-Max; VIL-0.4 V 


VCC=-Max; DC Cond. 


VCC-Max 


VLSI TECHNOLOGY, INC 


S 


FEATURES 
- On-chip PLL data separator 


- On-chip write precompensation logic 


- Single +5 V supply 


- Accxammodates single and double 
density formats 
IBM 3740 (FM) 
IBM 34 
(MFM) 


- Automatic seek with verify 


- Multiple sector read/write 


- TIL compatible 


- Programmable control 
-Selectable track-to-track access 
—Head load timing 


- Software compatible with the FD179X 
senes 


- Soft sector format compatibility 
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FLOPPY DISK FORMATI'ER/ 


DESCRIPTION 
The VL279X are N-Channel Silicon 
Gate MOS LSI devices which perform 
the functions of a Floppy Disk Format- 
ter/Controller in a single chip implemen- 
tation. The VL279X, which can be 
considered the end result of both the 
FD1771 and FD179X designs, is IBM 
3740 compatible in single density mode 
(FM) and System 34 compatible in 
Double Density Mode (MFM). The 
VL279X contains all the features of its 
predecessor the FD179X plus a high 
performance Phase-Lock-Loop Data 
Separator as well as Write Precompen- 
sation Logic. In Double Density mode, 
Write Precompensation is automatically 
engaged to a value programmed via an 
external potentiometer. In order to 
maintain compatibility, the FD1771, 
FD179X and VL279X designs were 


CONTROLLER FAMILY 


made as close as possible with the 
computer interface, instruction set, and 
UO registers being identical. Also, head 
load control is identical. In each case, 
the actual pin assignments vary by only 
a few pins from any one to another. 


The processor interface consists of an 
8-bit bidirectional bus for data, status, 
and control word transfers. The 
VL279X is set up to operate on a 
multiplexed bus with other bus-oriented 
devices. 


The VL279X is TTL compatible on all 
inputs and outputs. The outputs will 
drive one TIL load or three LS loads. 
The VL2793 is identical to the 2791 
except the DAL lines are TRUE for 
systems that utilize true data busses. 


The 2793/7 has a side select output for 
controlling double sided drives. 


PIN DIAGRAM 
ORDER INFORMATION 


EMF. 
M5 
9§. 
RE 
A0 
A1 
DALO 
DAL1 
DAL2 
DAL3 
DAL4 
DAL5 
DAL6 
DAL7 
step 
DIRC 
s/a 
REY." 
MR 
GND 


\lO'$U'lb(0l\)-5 
8 
9 
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VL2797 


10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 


40 
39 
38 
37 


'-‘-‘R§<'3'§883'8L>38‘-$882268 


HLT 
INTRO 
QF.@_ 
oosu 
_W_PRT 
L. 
noo 
PW 
EADY 


E532-IQ0 
TG43 
HLD 
RAW RD 
VCO 
SSO/ENMF 
CLK 
PUMP 
TEST 
VCC 


Part 
Number 


VL2793-PC 
VL2793-CC 


VL2797-PC 
VL2797-CC 


Plastic DIP 
Sid“ 
Ceramic DIP 


Doub|e- 
Plastic DIP 
Sided 
Ceramic DIP 


Note: Operating temperature range is 0°C to +70°C. 
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PIN DESCRIPTION 


PIN NUMBER 
PIN NAME 


ENABLE PRECOMP 
1 


19 


20 


21 
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MASTER RESET 


POWER SUPPLIES 


COMPUTER INTERFACE: 


2 


3 


4 


5,6 


7-14 


24 


38 


39 


FLOPPY DISK INTERFACE: 


15 


16 


17 


18 


22 
154 


WRITE ENABLE 


CHIP SELECT 


READ ENABLE 


REGISTER SELECT LINE 


DATA ACCESS LINES 


CLOCK 


DATA REQUEST 


INTERRUPT REQUEST 
. 


STEP 
DIRECTION 


51/4 
e" SELECT 


READ PULSE WIDTH 


TESI 


SYMBOL 
ENP 


WT 


Vss 
Vcc 


VW 


Ci 


RE 


A0, A1 


DAL0-DAL7 


CLK 


DRQ 


INTRO 


STEP 


DIRC 


5/8 


RPW 


I EST 
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FUNCTIONT 
T T 
T 
T 
T 
I 
I 
I*_1l 
I 
I 
I 
I 
A Logic high on this input enables write precompen- 
sation to be performed on double density Write Data 
output only. 
A logic low (50 microseconds min.) on this input 
resets the device and loads HEX 03 into the com- 
mand register. The Not Ready (Status Bit 7) is reset 
during MR ACTIVE. When MTR is brought to a logic 
high a RESTORE Command is executed, regardless 
of the state of the Ready signal from the drive. Also, 
HEX 01 is loaded into sector register. 


Ground 


+ 5V z 5% 


A logic low on this input gat_es data on the DAL into 
the selected register when CS is low. 


A logic low on this input selects the chip and enables 
computer communication with the device. 


A logic low on this input controls the placemelt of 
data from a selected register on the DAL when CS is 
low. 
These inputs select the register to_receive/transfer 
data on the DAL lines under RE and WE control: 
65 
A1 
A0 
RE 
W2 
Status Reg 
Command Reg 
Track Reg 
Track Reg 
Sector Reg 
Sector Reg 
Data Reg 
Data Reg 


Eight bit bi-directional bus used for transfer of com- 
mands, status, and data These lines are inverted 
(active low) on VL279X. 
This input requires a free-running 50% duty cycle 
square wave clock for internal timing reference, 2 
MHz 1- 1% for 8" drives, 1 MHz 
;i_- 1% for mini- 
floppies. 
This output indicates that the Data Register contains 
assembled data in Read operations, or the DR is 
empty in Write operations. This signal is reset when 
serviced by the computer through reading or loading 
the DR. 
This output is set at the completion of any command 
and is reset when the Status register is read or the 
Command register is written to. 


OOCDO 
-l-BOO 
_AQ_wQ 


The step output contains a pulse for each step. 


Direction Output is active high when stepping in, 
active low when stepping out. 
This input selects the internal VCO frequency for use 
with 51/4 " drives or 8" drives. 


An external potentiometer tied to this input controls 
the phase comparator within the data separator. 
A logic low on this input allows adjustment of exter- 
nal resistors by enabling Internal signals to appear on 
selected pins. 


PIN DESCRIPTION (Continued) 


J 
PIl_\_l__NUMBER 
PIN 
_ 


1 
1 
1 
I 
23 
‘ 


25 
- 


I 


PUMP 


ENABLE MINI-FLOPPY 
( 2793) 


SIDE SELECT OUTPUT 
(2797) 


VOLTAG E-CONTROLLED 
OSCILLATOR 


RAW READ 


HEAD LOAD 


TRACK GREATER 
I 
THAN 43 


WRITE GATE 


WRITE DATA 


READY 


WRITE PRECOMP 
WIDTH 


TRACK 00 


INDEX PULSE 


WRITE PROTECT 
I 


DOUBLE DENSITY 


HEAD LOAD TIMING 
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SYMBOL 


PUMP 


ENMF 


SSO 


VCO 


RAW READ 


H LD 


TG43 


WG 


WD 


READY 


WPW 


TR00 


|T> 


A 
WPRT 


DDEN 


HLT 
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-1 
I1 
_; 
1-In-Q-nun-can-| 
r'_n1_rrI'. 
l 
_ 
in 
F"“°TL°“ 
- 
- 
High-Impedance output signal which is forced high 
or low to increase/decrease the VCO frequency. 


A logic low on this input enables an internal +2 of 
the Master Clock. This allows both 5‘/4 " and 8" drive 
operation with a single 2 MHz clock. For a 1 MHz 
clock on Pin'24, this line must be left open or tied to a 
Logic 1. 


The logic level of the Side Select Output is directly 
controlled by the ‘S’ flag in Type ll or Ill commands. 
When U = 1, SSO is set to a logic 1. When U = 0, 
SSO is set to a logic 0. The SSO is compared with the 
side information in the Sector l.D. Field. If they do not 
compare Status Bit 4 (RNF) is set. The Side Select 
Output is only updated at the beginning of a Type ll or 
lll command. It is forced to a logic 0 upon a MASTER 
RESET condition. 


An external capacitor tied to this pin adjusts the VCO 
center frequency. 


The data input signal directly from the drive. This 
input shall be a negative pulse for each recorded flux 
transition. 


The HLD output controls the loading of the Read- 
Write head against the media 


This output informs the drive that the Read/Write 
head is positioned between tracks 44-76. This output 
is valid only during Read and Write Commands. 
This output is made valid before writing is to be 
performed on the diskette. 
MFM or FM output pulse per flux transition. WD 
contains the unique Address marks as well as data 
and clock in both FM and MFM formats. 
This input indicates disk readiness and is sampled 
for a logic high before Read or Write commands are 
performed. 
If Ready is low the 
Read or Write 
operation is not performed and an interrupt is 
generated. Type I operations are performed regard- 
less of the state of Ready. The Ready input appears in 
inverted format as Status Register bit 7. 


An external potentiometer tied to this input controls 
the amount of delay in Write precompensation mode. 


This input informs the VL279X that the Read/Write 
head is positioned over Track 00. 
This input informs the VL279X when the index hole 
is encountered on the diskette. 
This input is sampled whenever a Write Command is 
received. A logic low terminates the command and 
sets the Write Protect Status bit. 
This input pin selects either single or double density. 
operation. When DDEN 
= 
0, double density is 
selected. When 
DDEN 
= 
1, single density 
is 
selected. 


When a logic high is found on the HLT input the head 
is assumed to be engaged. It is typically derived from 
a1 shot triggered by HLD. 


Figure 1. 
® VLSI TEc1-1NoLocY, INC. 
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8" FLOPPY AND 5‘/4" MINI FLOPPY CONTROLLER 
SINGLE OR DOUBLE DENSITY 
CONTROLLER/FORMATTER 


The VL279X Family are MOSILSI devices which perform 
the functions of a Floppy Disk ControllerlFormatter. Soft- 
ware compatible with its predecessor, the FD179X, the 
device also contains a high performance Phase-Lock-Loop 
Data Separator as well as Write Precompensation Logic. 


When operating in Double Density mode, Write Precom- 
pensation may be enabled, its value predetermined by an 
external 
potentiometer. 
An 
on-chip 
VCO 
and 
phase 
comparator allows adjustable frequency range for_5l/4 " or 
8" Floppy Disk interfacing. 


The VL279X is fabricated in NMOS silicon gate technology 
and available in a 40 pin dual-in-line package. 


’ 117 
I*’ 
1 
1 
*1 
_ 
*_ 
_ 
FEATURES 
2793 
1 
2191 
I 
_ 
________ 
x 
x 
Single Density (FM) 
Double Density (MFM) 
X 
X 
True Data Bus 
L 
X_ 
I 
X 
Inverted Data Bus 
‘ 
‘ 
Side Select Out 
Internal CLK Divide 
l 
X 
. 


>< 


ORGANIZATION 
The Floppy Disk Formatter block diagram is illustrated on 
page 5. The primary sections include the parallel processor 
interface and the Floppy Disk interface. 
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Data Shift Register — This 8-bit register assembles serial 
data from the Read Data input (RAW READ) during Read 
operations and transfers serial data to the Write Data 
output during Write operations. 


Data Register — This 8-bit register is used as a holding 
register during Disk Read and Write operations in Disk 
Read operations the assembled data byte is transferred in 
parallel to the Data Register from the Data Shift Register. In 
Disk Write operations information is transferred in parallel 
from the Data Register to the Data Shift Register. 
When executing the Seek command the Data Register 
holds the address of the desired Track position. This 
register is loaded from the DAL and gated onto the DAL 
under processor control. 
Track Register — This 8-bit register holds the track number 
of the current ReadlWrite head position. It is incremented 
by one every time the head is stepped in (towards track 76) 
and decremented by one when the head is stepped out 
(towards track 00). The contents of the register are com- 
pared with the recorded track number in the ID field during 
disk Read, Write and Verify operations. The Track Register 
can be loaded from or transferred to the DAL. This Register 
should not be loaded when the device is busy. 
Sector Register (SR) — This 8-bit register holds the address 
of the desired sector position. The contents of the register 
are compared with the recorded sector number in the ID 
field during disk Read or Write operations. The Sector 
Register contents can be loaded from or transferred to the 
DAL. This register should not be loaded when the device is 
busy. 
Command Register (CR) — This 8-bit register holds the 
command presently being executed. This register should 
not be loaded when the device is busy unless the new 
command is a force interrupt. The command register can 
be loaded from the DAL, but not read onto the DAL 
Status Register (STR) — This 8-bit register holds device 
Status information. The meaning of the Status bits is a 
function of the type of command previously executed. This 
register can be read onto the DAL, but not loaded from the 
DAL. 
CRC Logic - This logic is used to check or to generate the 
16-bit Cyclic Redundancy Check (CRC). The polynomial is: 
G(x) = x15 + x12 + x5 +1. 


The CRC includes all information starting with the address 
mark and up to the CRC characters. The CRC register is 
preset to ones prior to data being shifted through the 
circuit. 
ArithmeticILogic Unit (ALU) — The ALU is a serial compara- 
tor, incrementer, and decrementer and is used for register 
modification and comparisons with the disk recorded ID 
field. 
Timing and Control - All computer and Floppy Disk in- 
terface controls are generated through this logic. The in- 
ternal device timing is generated from an external crystal 
clock. 
AM Detector - The address mark detector detects ID, data 
and index address marks during read and write operations. 
Write Precompensation — enables write precompensation 
to be performed on the Write Data output. 
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Data Separator — a high performance Phase-Lock-Loop 
Data Separator with on-chip VCO and phase comparator 
allows adjustable frequency range for 5‘/4" or 8" Floppy 
Disk interfacing. 


PROCESSOR INTERFACE 
The interface to the processor is accomplished through the 
eight Data Access Lines (DAL) and associated control 
signals. The DAL are used to transfer Data, Status, and 
Control words out of, or into the VL279X. The DAL are 
three state buffers that are enabled as output drivers when 
Chip Select (CS) and Read Enable (RE) are active (low logic 
state) or act as input receivers when (E and Write Enable 
(V_WE)are active. 


When transfer of data with the Floppy Disk Controller is 
required by the host processor, the device address is 
decoded and CS is made low. The address bits A1 and A0, 
combined with the signals FTE during a Read operation or 
WE during a Write operation are interpreted as selecting 
the following registers: 
it 
A 
A 
A1 
- A0 
READ(RE) 
WRITE (WE) 
Status Register 
Command Register 
Track Register 
Track Register 
Sector Register 
Sector Register 
Data Register 
Data Register 
----oo 
-L 
(:)-a- 
(:) 


ML! 


During Direct Memory Access (DMA) types of data trans- 
fers between the Data Register of the VL279X and the 
processor, the Data Request (DRO) output is used in Data 
Transfer control. This signal also appears as status bit 1 
during Read and Write operations. 


On Disk Read operations the Data Request is activated (set 
high) when an assembled serial input byte is transferred in 
parallel to the Data Register. This bit is cleared when the 
Data Register is read by the processor. If the Data Register 
is read after one or more characters are lost, by having new 
data transferred into the register prior to processor readout, 
the Lost Data bit is set in the Status Register. The Read 
operation continues until the end of sector is reached. 


On Disk Write operations the data Request is activated 
when the Data Register transfers its contents to the Data 
Shift Register, and requires a new data byte. It is reset when 
the Data Register is loaded with new data by the processor. 
If new data is not loaded at the time the next serial byte is 
required by the Floppy Disk, a byte of zeroes is written on 
the diskette and the Lost Data bit is set in the Status 
Register. 
At the completion of every command an 
INTRO 
is 
generated. INTRO is reset by either reading the status 
register or by loading the command register with a new 
command. In addition, INTRO is generated if a Force ln- 
terrupt command condition is met. 
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The 279X has two modes of operation according to the 
state of DDEN (Pin 37). When DDEN = 1, Single Density 
(FM) is selected. When DDEN 
.-= 0, Double Density (MFM) 
is selected. In either case, the CLK input (Pin 24) is set at 2 
MHz for 8" drives or 1 MHz for 51/4 " drives. 


On the 2791/2793, the ENMF input (Pin 25) can be used for 
controlling both 51/4 " and 8" drives with a single 2 MHz 
clock. When ENMF = 0, an internal 
-:- 2 of the CLK is 
performed. When ENMF = 1, no divide takes place. This 
allows the use of a 2 MHz clock for both 51/4 " and 8" 
configurations. 
The internal VCO frequency must also be set to the proper 
value. The Q8 input (Pin 17) is used to select data separator 
operation by internally dividing the Read Clock. When 5/8 
= 0, 51/4 " data separation is selected; when 5/8 = 1, 3" 
drive data separation is selected. 


2 MHz 
1 
1 
8" 
2 MHz 
0 
0 
51/4 " 


1 MHz 
1 
0 
51/4 " 


CLOCK(24) i ENMF(25) 
‘ 
5/am) 
H 
oalvs 


FUNCTIONAL DESCRIPTION 
The VL279X is software compatible with the FD179X series 
of Floppy Disk Controllers. Commands, status, and data 
transfers are performed in the same way. Software generated 
for the 179X can be transferred to a 279X system without 
modification. 


In addition to the 179X, the 279X contains an internal Data 
Separator and Write precompensation circuit. The TEST 
(Pin 22) line is used to adjust both data separator and pre 
compensation. When TEST = 0, the WD (Pin 31) line is 
internally connected to the output of the write precomp 
oneshot. Adjustment of the WPW (Pin 33) line can then be 
accomplished. A second oneshot tracks the precomp set- 
ting at approximately 3:1 to insure adequate Write Data 
pulse widths to meet drive specifications. 


Similarly, Data separation is also adjusted with T?ST' = 0. 
The TG43 (Pin 29) line is internally connected to the output 
of the read data one-shot, which is adjusted via the RPW 
(Pin 18) line. The DIRC (Pin 16) line contains the Read Clock 
output (.5 MHz for 8" drives). The VCO Trimming capacitor 
(Pin 26) is adjusted for center frequency. 


Internal timing signals are used to generate pulses during 
the adjustment mode so that these adjustments can be 
made while the device is in-circuit. The I?E'S_T line also 
contains a pull-up resistor, so adjustments can be per- 
formed simply by grounding the T-'_E_S_T pin, overriding the 
pull-up. The TEST pin cannot be used to disable stepping 
rates during operation as its function is quite different from 
the 179X. 
Other pins on the device also include pull-up resistors and 
may be left open to satisfy a_Logic 1 condition. These are: 
ENP, 5/8, ENMF, WPRT, DDEN, HLT, TEST, and W2. 


GENERAL DISK READ OPERATIONS 
Sector lengths of 128, 256, 512 or 1024 are obtainable in 
either FM or MFM formats. For FM, DDEN should be 
placed to logical 
For MFM formats, DDEN should be 
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Sector Length Table‘ 
W 
Sector Length 
Number of Bytes 
Field (hex) 
in Sector (decimal), 


O0 
128 
01 
256 
02 
512 
03 
1024 


12793/97 may vary -— see command summary. 


placed to a logical 
Sector lengths are determined at 
format time by the fourth byte in the “lD" field. 


The VL279X recognizes tracks and sectors numbered 00- 
FFX. However, due to programming restrictions, only tracks 
and sectors O0 thru F4 can be formatted. 


GENERAL DISK WRITE OPERATION 
When writing is to take place on the diskette the Write Gate 
(WG) output is activated, allowing current to flow into the 
ReadlWrite head. As a precaution to erroneous writing the 
first data byte must be loaded into the Data Register in 
response to a Data Request from the 279X before the Write 
Gate signal can be activated. 


Writing is inhibited when the Write Protect input is a logic 
low, in which case any Write command is immediately 
terminated, an interrupt is generated and the Write Protect 
status bit is set. 


For write operations, the 279X provides Write Gate (Pin 30) 
and Write Data (Pin 31) outputs. Write data consists of a 
series of pulses set to a width approximately three times 
greater than the precomp adjustment. Write Data provides 
the unique address marks in both formats. 


READY 
Whenever a Read or Write command (Type ll or Ill) is 
received the 279X samples the Ready input. If this input is 
logic low the command is not executed and an interrupt is 
generated. All Type I commands are performed regardless 
of the state of the Ready input. Also, whenever a Type ll or 
lll command is received, the TG43 signal output is updated. 
TG43 may be tied to ENP to enable write precompensation 
on tracks 44-76. 


COMMAND DESCRIPTION 
The VL279X will accept eleven commands. Command 
words should only be loaded in the Command Register 
when the Busy status bit is off (Status bit O). The one ex- 
ception is the Force interrupt command. Whenever a 
command is being executed, the Busy status bit is set. 
When a command is completed, an interrupt is generated 
and the Busy status bit is reset. The Status Register in- 
dicates whether the completed command encountered an 
error or was fault free. For ease of discussion, commands 
are divided into four types. Commands and types are 
summarized in Table 1. 
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TABLE 1. 
COMMAND SUMMARY 
A. Commands for Model 2793 
B. Commands for Model 2797 
Bits 
Bits 


------ooooo~: 
-A--A-00--000 
0'5 
o-4-4o-0-0-co01 
.4-40033-I-I-1-0 
as 
¢FOOO(D(D:r:r:':r3' 
no 
rG'mmrnmm<<<<< 
to 
Jooo 


Type Command 
1 


I 
Restore 
'1 
I 
Seek 
'1 
Step 
'1 
Step-in 
'1 
Stepout 
'1 
ll 
Read Sector 
C 
ll 
Wrlte Sector 
C 
lll 
ReadAddress 
lll 
Read Track 
Ill 
WrlteTrack 
IV 
Forcelnterrupt 


TABLE2. 
FLAG SUMMARY 


Command 
Type 


I 
0, 1 
'1 '0 = Stepping Motor Rate 
See Table 3 for Rate Summary 


I 
2 
V = Track Number Verify Flag V 
V 


I 
3 
h = Head Load Flag 
h 
h 


I 
4 
T = Track Update Flag 
T 
T 


" & "I 
0 
80 = Data Address Mark 
80 = 0, FB (DAM) 
30 = 1, F8 (deleted DAM) 


ll 
1 
C = Side Compare Flag 
C 
C 


ll & Ill 
1 
U = Update SSO 
U 
U 


II 81 III 
2 
E = 15 MS Delay 
E 
E 


ll 
3 
S = Side Compare Flag 
S 
S 


ll 
3 
L = Sector Length Flag 


L 


ll 
4 
m = Multiple Record Flag 
m = 0,Slngle record 
m = 1,Multlple records 


1v 
oa 
Ix 
= Interrupt Condition Flags 
I0 
= 1 Not Ready To Ready Transition 
:1 
= 1 Ready To Not Ready Transition 
2 
= 1 Index Pulse 
I3 
= 
1 Immediate Interrupt, Requires A Reset‘ 
I3-lg 
= 0 Terminate With No Interrupt (INTRO) 


‘ NOTE: See Type IV Command Description for further information. 


1 59 


= 0, No verify 
= 1, Verify on destination track 


= 0, No update 
= 1, Update track register 


= 0, Disable side compare 
= 1, Enable side compare 


= 0, Update SSO to 0 
= 1, Update SSO to 1 


= 0, Compare for side 0 
= 1, Compare for slde1 


LSB's Sector Length in ID Field 


L 
-- 0 
256 
512 
1024 
128 


6Q¢Q8¢66666o 
------ooooo~: 
----oo--0000: 
Q—l—lQ-‘Q-‘Q-‘CO 
U’! 
rG'mmmmm<<<<< 
to 
-A--0033-1-1-I-o 
-it 
(:;"O"(DOl-I-3'D'3'33' 
on 


CCJSSJJ 


W -5 


Description 


0, Unload head at beginning 
1, Load head at beginning 


0, No. 15 MS delay 
1,15 MS delay (30 MS for 1 MHz) 
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CCC- 


6oo¢3o66666¢ 


= 1 
128 
256 
512 
1024 
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Write Precompensation 
When operating in Double Density mode (DDEN = 0), the 
279X 
has 
the capability of providing 
a 
user-defined 
precompensation 
value 
for Write 
Data. 
An 
external 
potentiometer (10K) tied to the WPW signal (Pin 33) allows a 
setting of 100 to 300 ns from nominal. 
Setting the Write precomp value is accomplished by for- 
cing the TEST line (Pin 22) to a Logic 0. A stream of pulses 
can then be seen on the Write Data (Pin 31) line. Adjust the 
WPW Potentiometer for the desired pulse width. This 
adjustment may be performed in-circuit since Write Gate 
(Pin 30) is inactive while TEST = 0. 


Data Separation 
The 279X can operate with either an external data separator 
or its own internal recovery circuits. _T_he condition of the 
TEST line (Pin 22) in conjunction with MR (Pin 19) will select 
internal or external mode. 


To program the 279X for external VCO, a MR pulse must be 
applied while TTsT = 0. A clock equivalent to eight times 
the data rate (e.g., 4.0 MHz for 8" Double Density) is applied 
to the VCO input (Pin 26). The feedback reference voltage is 
available on the Pump output (Pin 23) for external in- 
tegration to control the VCO. TEST is returned to a Logic 1 
for normal operation. Note:_T_<_> maintain this mode, 11% 
must be held low whenever MR is applied. 


For internal_\/_CO operation, the TEST line must be high 
during the MR pulse, then set to a Logic 0 for the ad- 
justment procedure. 


A 50K Potentiometer tied to the RPW input (Pin 18) is used 
to set the internal Read Data pulse for proper phasing. With 
a scope on Pin 29 (TG43), adjust the RPW pulse for 1/8 of 
the data rate (250 ns for 8" Double Density). An external 
variable capacitor of 5-60 pf is tied to the VCO input (Pin 26) 
for adjusting center frequency. With a frequency counter 
on Pin 16 (DIRC) adjust the trimmer cap to yield the ap- 
propriate Data Rate (500 KHz for 8" Double Density). The 
DDEN line must be low while the 5/8 line is held high or the 
adjustment times above will be doubled. 
After adjustments have been made, the TEST pin is 
returned to a Logic 1 and the device is ready for operation. 
Adjustments may be made in-circuit since the DIRC and 
TG43 lines may toggle without affecting the drive. 
The PUMP output (Pin 23) consists of positive and negative 
pulses, which their duration ls equivalent to the phase 
difference of incoming Data vs. VCO frequency. This signal 
is internally connected to the VCO input, but a Filter is 
needed to connect these pulses to a slow moving DC 
vohage. 


The internal phase-detector is unsymmetrical for a random 
distribution of data pulses by a factor of two, In favor of a 
PUMP UP condition. Therefore, it is desirable to have a 
PUMP DOWN twice as responsive to prevent run-away 
during a lock attempt. 


A first order lag-lead filter can be used at the PUMP output 
(Pin 23). This filter controls the instantaneous response of 
the VCO to bit-shifted data (jitter) as well as the response to 
normal frequency shift, i.e., the lock-up time. A balance 
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must be accomplished between the two conditions to 
inhibit over-responsiveness to jitter and to prevent an 
extremely wide lock-up response, leading to PUMP run- 
away. The filter affects these two reactions in mutually 
opposite directions. 


The 
following 
Filter Circuit 
is recommended 
for 8" 
FMIMFM: 


PUMP 
(PH423) 
51f 
I 
- I4 


1KQ 
IN914 


Since 51/4 " Drives operate at exactly one-half the data rate 
(250 Kblsec) the above capacitor should be doubled to .2 or 
.22,1t. 


TYPE I COMMANDS 
The Type I Commands include the Restore, Seek, Step, 
Stepin, and StepOut commands. Each of the Type 
I 
Commands contains a rate field (rg r1), which determines 
the stepping motor rate as defined in Table 3. 


A 2ps (MFM) or 4 ps (FM) pulse is provided as an output to 
the drive. For every step pulse issued, the drive moves one 
track location in a direction determined by the direction 
output. The chip will step the drive in the same direction it 
last stepped unless the command changes the direction. 


The Direction signal is active high when stepping in and 
low when stepping out. The Direction signal is valid before 
the first stepping pulse is generated. 
The rates (shown in Table 3) can be applied to a Step 
Direction Motor through the device interface. 


TABLE 3. STEPPING RATES 


CLK 
2 MHZ 
1 MHZ 
R1 
R0 
TEST = 1 
TEST = 1 
3 ms 
6 ms 
6 ms 
12 ms 
10 ms 
20 ms 
15 ms 
30 ms 


—l~—l~QO 
—*CD—lQ 


After the last directional step an additional 15 milliseconds 
of head settling time takes place if the Verify flag is set in 
Type I commands. Note that this time doubles to 30 ms for 
a 1 MHz clock. There is also a 15 ms head settling time if 
the E flag is set in any Type ll or Ill command. 


When a Seek, Step or Restore command is executed an 
optional verification of Read-Write head position can be 
performed by setting bit 2 (V = 1) In the command word to 
a logic 1. The verification operation begins at the end of the 
15 millisecond settling time after the head is loaded against 
the media. The track number from the first encountered ID 


160 
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Field is compared against the contents of the Track 
Register. If the track numbers compare and the ID Field 
Cyclic Redundancy Check (CRC) is correct, the verify 
operation is complete and an INTRO is generated with no 
errors. If there is a match but not a valid CRC, the CRC error 
status bit is set (Status bit 3), and the next encountered ID 
field is read from the disk for the verification operation. 
- 


The VL279X 
must find an ID field with correct track 
number and correct CRC within 5 revolutions of the media; 
othenrvise the seek error is set and an INTRO is generated. 
If V = 0, no verification is performed. 


The Head Load (HLD) output controls the movement of the 
readlwrite head against the media. HLD is activated at the 
beginning of aType I command if the h flag is set (h = 1), at 
the end of the Type I command if the verify flag (V = 1), or 
upon receipt of any Type ll or Ill command. Once HLD is 
active it remains active until either a Type I command is 
received with (h = 0 and V = 0); or if the 279X is in an idle 
state (non-busy) and 15 index pulses have occurred. 


Head Load timing (HLT) is an input to the 279X which is 
used for the head engage time. When HLT = 1, the 279X 
assumes the head is completely engaged. The head 
engage time is typically 30 to 100 ms depending on drive. 
The low to high transition on HLD is typically used to fire a 
one shot. The output of the one shot is then used for HLT 
and supplied as an input to the 279X. 


HEAD LOAD TIMING 


I 
r--—.- 
I-—i——— 


HLT (FROM ONE SHOT) 


\} I I 
I13O 


When both HLD and HLT are true, the 279X will then read 
from or write to the media. The “and" of HLD and HLT ap- 
pears as status Bit 5 in Type I status. 


In summary for the Type I commands: if h = 0 and V = 0, 
HLD is reset. If h = 
1 and V = 0, HLD is set at the 
beginning of the command and HLT is not sampled nor is 
there an internal 15 ms delay. If h = 0 and V = 1, HLD is set 
near the end of the command, an internal 15 ms occurs, 
and the 279X waits for HLT to be true. If h = 1 and V = 1, 
HLD is set at the beginning of the command. Near the end 
of the command, after all the steps have been issued, an 
internal 15 ms delay occurs and the 279X then waits for HLT 
to occur. 


For Type II and Ill commands with E flag off, HLD is made 
active and HLT is sampled until true. With E flag on, HLD is 
made active‘, an internal 15 ms delay occurs and then HLT is 
sampled until true. 


RESTORE (SEEK TRACK 0) 
Upon receipt of this command the Track 00 (TFWO) input is 
sampled. If TRW is active low indicating the Read-Write 
head is positioned over track 0, the Track Register is loaded 
with zeroes and an interrupt is generated. If T_RTO is not 
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active low, stepping pulses at a rate specified by the 1110 
field are issued until the TRTO Input is activated. At this 
time the Track Register is loaded with zeroes and an in- 
terrupt ls generated. If the TRT input .does not go active 
low after 255 stepping 
pulses, 
the 279X terminates 
operation, interrupts, and sets the Seek error status bit. A 
verification operation takes place if the V flag ls set. The h 
bit allows the head to be loaded at the start of command. 
Note that the Restore command Is executed when WI 
goes from an active to an inactive state. 


SEEK 
This command assumes that the Track Register contains 
the track number of the current position of the Read-Write 
head and the Data Register contains the desired track 
number. The VL279X will update the Track register and 
issue stepping pulses in the appropriate direction until the 


TYPE I COMMAND FLOW 


x . 


2Zz' 
O 
OO 


zO 


zO 


2O 


HAS 
A TYPE I 
COMMAND BEEN 
RECEIVED 


YES 


SET BUSY RESET CRC 
SEEK ERROR DRO INTRO 


YES 


SET HLD 
RESET HLD 


COMMAND 
YES 
SE1 
STEP IN 
DIRECTION 


COMMAND 
YES 
Q5551 


STEP out 
DIRECTION 
‘ 


COMMAND 
YES 
~ 
>- 
srev 
, 


no 
nncsronc 
YES 


rr rorn 


oroon 


YES 
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TYPE I COMMAND FLOW 


DR TO DSR 


5 


__L.T 


DOES 
yes 
TR 
DSR 


YES 


RESET DIRECTION 
SET DIRECTION 


DIRECTION 
"S 


1 to tn 
1 to rn 


HEAD AT 
ygs 
TRACK O AND 
0 1'0 1|: 
DIRECTION 


ISSUE 
ONE STEP PULSE 


I 


DELAY ACCORDING 
TO RI R0 FIELD 


COMMAND 
A STEP STEP IN 
OR STEP OUT 


vss 
® 


contents of the Track register are equal to the contents of 
the Data Register (the desired track location). A verification 
operation takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An interrupt 
is generated at the completion of the command. Note: 
When using multiple drives, the track register must be 
updated for the drive selected before seeks are issued. 


STEP 
Upon receipt of this command, the 279X issues one 
stepping pulse to the disk drive. The stepping motor 
direction is the same as in the previous step command. 
After a delay determined by the I110 field, a verification 
takes place if the V flag is on. If the T flag is on, the Track 
Register is updated. The h bit allows the head to be loaded 
at the start of the command. An interrupt is generated at 
the completion of the command. 


STEP-IN 
Upon receipt of‘ this command, the 279X issues one 
stepping pulse in the direction towards track 76. If the T 
flag is on, the Track Register is incremented by one. After a 
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TYPE I COMMAND FLOW 


VERIFY 
SEQUENCE 


1. 
ion-w¢‘|¢,-= 
II 


INTRO RESET BUSY 


v£S 


SET HLD 


HAS 
1! ll 
EXPIRED 


' 
YES 


I 
_ — 
- 
YES 


HAVE 
vss 
',,'gPg 
mrao asset eusv 
pAssE[ 
SET SEEK ERROR 


"O 
HAS 
I 
ID AM BEEN 
' 
I 
DETECTED 


YES 


oocs 
no 
rm nut 
""" n — 
' 
' 
ADDRESS or to 
new 


YES 


su 
vss 
'5 
N0 
we 
eI8i'2.'i.34 
"1" 
canon 
-, 
CBC 


mrno 
RESET BUSY 
- 


NOTE tum THERE NA TOMS DE1Av 


delay determined by the I110 field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An intenupt is generated at the 
completion of the command. 


STEP-OUT 
Upon receipt of this command, the 279X issues one 
stepping pulse in the direction towards track 0. If the T flag 
is on, the Track Register is decremented by one. After a 
delay determined by the I110 field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An interrupt is generated at the 
completion of the command. 


EXCEPTIONS 
On the 2797 device, the SSO output is not affected during 
Type I commands, and an internal side compare does not 
take place when the (V) Verity Flag is on. 


TYPE II COMMANDS- 
The ‘Type II Commands are the Read Sector and Write 
Sector commands. Prior to loading the Type ll Command 
into the Command Register, the computer must load the 
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Sector Register with the desired sector number. Upon 
receipt of the Type ll command, the busy status Bit is set. If 
the E flag = 1 (this is the normal case) HLD is made active 
and HLT is sampled after a 15 msec delay. If the E flag is 0, 
the head is loaded and HLT sampled with no 15 msec delay. 


When an ID field is located on the disk, the 279X compares 
the Track Number on the ID field with the Track Register. If 
there is not a match, the next encountered ID field is read 
and a comparison is again made. If there was a match, the 
Sector Number of the ID field is compared with the Sector 
Register. If there is not a Sector match, the next en- 
countered ID field is read off the disk and comparisons 
again made. If the ID field CRC is correct, the data field is 
then located and will be either written into, or read from 


TYPE ll COMMAND 


ENTER 


IS 
TYPE ll 
COMMAND 
RECEIVED 
7 


YES 


SET BUSY RESET DRO LOST 
DATA RECORD NOT FOUND I 
STATUS BITS 5 I B INTRO 


mrno 
""° 
asset eusv 


YES 


COPY S FLAG TO 
SSO LINE (2795 7 ONLY) 
< 
SET HLD 


NO 


YES 


SEE NOTE 


HAS 
“° 
ts us 
EXPIRED 
'7 
l 


YES 


NO 


YES 


YES 
scf 


TG43 


NO 


RESET TG43 


IS 
IS 
WRITE 
YES 
COMMAND 
PROTECT 
A 
ON 
WRITE 
1 
1 


NO 
_ 
NO 


INTRO RESET BUSY 
.SET WRITE PROTECT 


' 
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TYPE II COMMAND 


“AVE 
"S 
mrao asset ausv 
I 
5 '"2§§s‘;3 LES 
set necono-nor rou~o 


7 


I 
no 


HAS 
IDA“ 
p< 
No 
BEEN 
DETECTED 
1 


YES 


DOES 
HQ 
TR v TRACK 
--4--~ 
- 
ADDRESS OF I0 
FIELD 
‘I 


. 
YES 


1 
oocs 
N9 
sa - sccron 
" 
ADDRESS or to 
FIELD 
1 
| 
vss 


DOES 
NO 
S I SIDE NO. 
-<1 
c 
or 
to new 
2 
vss 


BRING IN SECTOR LENGTH FIELD 
STORE LENGTH IN INTERNAL 
REGISTER 


IS 
$51 cm; 
YES 
THERE A 
NO 
RESET 
snrus ERROR 
CRC ERROR 
cm; 


IS 
COMMAND 
NO 
A 


, 
.- 


YES 


depending upon the command. The 279X must find an ID 
field with a Track number, Sector nu mber, side number, and 
CRC within 5 revolutions of the disk; otherwise, the Record 
not found status bit is set (Status bit 4) and the command is 
terminated with an interrupt. 


Each of the Type ll Commands contains an (m) flag which 
determines if multiple records (sectors) are to be read or 
written, depending upon the command. If m = 0, a single 
sector is read or written and an interrupt is generated at the 
completion of the command. If m = 1, multiple records are 
read or written with the sector register internally updated 
so that an address verification can occur on the next 
record. The 279X will continue to read or write multiple 
records and update the sector register in numerical 
ascending sequence until the sector register exceeds the 
number of sectors on the track or until the Force Interrupt 
command is loaded into the Command Register, which 
terminates the command and generates an interrupt. 
For example: If the 279X is instructed to read sector 27 and 
there are only 26 on the track, the sector register exceeds 
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TYPE ll COMMAND 


READ SECTOR 
SEOUENCE 


MAS 
DATA AM 
“O 
OCCUREO 
IN TIME 


‘Y 


YES 


' 
PUT nccono rvwc |N 
STATUS REG BIT 5 


_ 
YES 


HAS 
F 
FIRST BYTE 
——- 
BEEN ASSEMBLEO 
IN OSR 


n1n‘|o| 


YE\ 
T 
,__:e 
_ 
_-- W 
._ 


SET DRO 


HAS 
NEIT BYTE 
BEEN ASSEMBLED 
IN OSR 


YES 


HAS 
BEEN 
""0 BY 
set DATA 
COMPUTER 
LQ51 
DRO 
0 


V 
ALL BYTES 
BEEN 
NPUTTEO 


YES 


CRC 
YES 
“anon 


YE s 


' 1 TO 
SECTOR RIG 


INTRO. RESET BUSY 
SET cnc ERROR 
‘ 
'|NTnO RESET BUSY 


the number available. The 279X will search for '5 disk 
revolutions, interrupt out, reset busy, and set the record not 
found status bit. 


The Type ll commands for the 2793 also contain side select 
compare flags. When C = 0 (Bit 1) no side comparison is 
made. When C = '1, the LSB of the side number is read off 
the ID Field of the disk and compared with the contents of 
the (S) flag (Bit 3). If the S flag compares with the side 
number recorded in the ID field, the 279X continues with 
the ID search. if a comparison is not made within 5 index 
pulses, the interrupt line is made active and the Record- 
Not-Found status bit is set. 


The Type ll and Ill commands for the 2797 contain a side 
select flag (Bit 1). When U = 0, SSO is updated to 0. 
Similarly, U = 1 updates SSO to 1. The chip compares the 
SSO to the ID field. If they do not compare within 5 
revolutions the interrupt line is made active and the RNF 
status bit is set. 


The 2797 READ SECTOR and WRITE SECTOR com- 


Y 


“° 
mt 
N0 
NO 
ALL a 
new w 
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TYPE ll COMMAND 


WRITE SECTOR 
SEQUENCE 


ocutv 2 avres or on 


|||| 
TH‘ 
‘llll 


SET DRO 


E DELAY O BYTES OF GAP 
1 


DR BEEN 
LOADED BY 
INTRO RESET BUSY 
COMPUTER 
~ tin t nAtA 
mi 


(DRO 
0 


YES 


OELA.v 
1 BYTE OF GAP 


YES 


TURN ON WG I WRITE 
E BYTES OF ZEROS 
DELAY H BYTES 


.¢¢5"»"$T§¢°¢<§‘.8§‘.m> 
w"‘" °“ “'6 ‘ "'"'" 
:2 avres or zcnos 
OE WRITE COMMAND 


DR TO DSR SET DRO 


WRITE BYTE TO DISK 


HAS 
OR BEEN 
No 
SET DATA 
LOADED 
LOST 
(Ono - O) 
WRITE BYTE 
1 
OF ZEHOS 


VEvrcs 
vss 
mnm 
wmrc cnc 
6 
WHITE 1 BYTE OF FF 


TURN OFF WC 


mands include a ‘L’ flag. The ‘L’ flag, in conjunction with 
the sector length byte of the ID Field, allows different byte 
lengths to be implemented in each sector. For IBM com- 
patibility, the ‘L’ flag should be set to a one. 


READ SECTOR 
Upon receipt of the Read Sector command, the head is 
loaded, the Busy status bit set, and when an ID field is 
encountered that has the correct track number, correct 
sector number, correct side number, and correct CRC, the 
data field is presented to the computer. The Data Address 
Mark of the data field must be found within 30 bytes in 
single density and 43 bytes in double density of the last ID 
field CRC byte; if not, the ID field search is repeated. 


When the first character or byte of the data field has been 
shifted through the DSR, it is transferred to the DB, and 
DRO is generated. When the next byte is accumulated in 
the DSR, it is transferred to the DR and another DRO is 
generated. If the Computer has not read the previous 
contents of the DR before a new character is transferred 
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that character is lost and the Lost Data Status bit is set. 
This sequence continues until the complete data field has 
been inputted to the computer. If there is a CRC error at the 
end of the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple sector 
command). 
At the end of the Read operation, the type of Data Address 
Mark encountered in the data field is recorded in the Status 
Register(Bit 5) as shown: 


STATUS 
BIT 5 


1 
Deleted Data Mark 
0 
Data Mark 


WRITE SECTOR 
Upon receipt of the Write Sector command, the head is 
loaded (HLD active) and the Busy status bit is set. When an 
ID field is encountered that has the correct track number, 
correct sector number, correct side number, and correct 
CRC, a DRO is generated. The 279X counts off 11 bytes in 
single density and 22 bytes in double density from the CRC 
field and the Write Gate (WG) output is made active if the 
DRQ is serviced (i.e., the DR has been loaded by the 
computer). If DRQ has not been serviced, the command is 
terminated and the Lost Data status bit is set. If the DRO 
has been serviced, the WG is made active and six bytes of 
zeroes in single density and 12 bytes in double density are 
then written on the disk. At this time the Data Address 
Mark is then written on the disk as determined by the 30 
field of the command as shown below: 


I 
30 
Data_Address Mark (Bit 0) 


1 
Deleted Data Mark 
0 
Data Mark 


The 279X then writes the data field and generates DRQ’s to 
the_ computer. If the DRQ is not serviced in time for con- 
tinuous writing the Lost Data Status Bit is set and a byte of 
zeroes is written on the disk. The command is not ter- 
minated. After the last data byte has been written on the 
disk, the two-byte CRC is computed internally and written 
on the disk followed by one bye of FE in FM or in MFM. The 
WG output is then deactivated. For a 2 MHz clock the 
INTRQ will set 8 to 12 ).4S8C after the last CRC byte is 
written. For partial sector writing, the proper method is to 
write the data and fill the balance with zeroes. By letting the 
chip fill the zeroes, errors may be masked by the lost data 
status and improper CRC Bytes. 


TYPES lll COMMANDS 
READ ADDRESS 
Upon receipt of the Read Address command, the head is 
loaded and the Busy Status Bit is set. The next en- 
countered ID field is then read in from the disk, and the six 
data bytes of the ID field are assembled and transferred to 
the DR, and a DRQ is generated for each byte. The six bytes 
of the ID field are shown below: 


165 
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TRACK 
SIDE 
secfoa 
SECTOR 
cac cad 
ADDR 
NUM_BER ADDRESS 
LENGTH 
1 
2 
1_ 
2__ 
3 
4 
5 
e 


Although 
the CRC characters are transferred to the 


computer, the 279X checks for validity and the CRC error 
status bit is set if there is a CRC error. The Track Address of 
the ID field is written into the sector register so that a 
comparison can be made by the host. At the end of the 
operation an interrupt is generated and the Busy Status is 
reset. 
READ TRACK 
Upon receipt of the READ track command, the head is 
loaded, and the Busy Status bit is set. Reading starts with 
the leading edge of the first encountered index pulse and 
continues until the next index pulse. All Gap, Header, and 
data bytes are assembled and transferred to the data 
register and DRQ’s are generated for each byte. The ac- 
cumulation of bytes is synchronized to each address mark 
encountered. An interrupt is generated at the completion of 
the command. 


This command has several characteristics which make it 
suitable for diagnostic purposes. They are: 
no CRC 
checking is performed; gap information is included in the 
data stream; the internal side compare is not performed; 
and the address mark detector is on for the duration of the 
command. Because the A.M. detector is always on, write 
splices or noise may cause the chip to look for an A.M. If an 
address mark does not appear on schedule with the Lost 
Data status flag being set. 


The ID A.M., ID field, ID CRC bytes, DAM, Data and Data 
CRC Bytes for each sector will be correct. The Gap Bytes 
may be read incorrectly during write-splice time because of 
synchronization. 


WRITE TRACK FORMATTING THE DISK 
(Refer to section on Type lll commands for flow diagrams.) 
Formatting the disk is a relatively simple task when operat- 
ing programmed IIO or when operating under DMA with a 
large amount of memory. Data and gap information must be 
provided at the computer interface. Formatting the disk is 
accomplished by positioning the R/W head over the de- 
sired track number and issuing the Write Track command. 


Upon receipt of the Write Track command, the head is 
loaded and the Busy Status bit is set. Writing starts with 
the leading edge of the first encountered index pulse and 
continues until the next index pulse, at which time the 
interrupt is activated. The Data Request is activated im- 
mediately upon receiving the command, but writing will not 
start until after the first byte has been loaded into the Data 
Register. if the DR has not been loaded by the time the 
index pulse is encountered the operation is terminated 
making the device Not Busy, the Lost Data Status Bit is set, 
and the interrupt is activated. lf a byte is not present in the 
DR when needed, a byte of zeroes is substituted. 
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TYPE Ill COMMAND WRITE TRACK 
TYPE Ill COMMAND Read Tracl<lAddress 


NO 


NO 


YES 


SET BUSY. RESET DRO. 
LOST DATA, STATUS 
BITS 4. 5 


NO 


YES 


SET HLD 


COPY S FLAG TO 
SSO LINE (2795 7 ONLY) 


YES 


HAS 
15 MS 
EXPIRED 
7 


NO 


X 
__ 
" 
YES 


INTRO RESET 
BUSY SET WPRT 


SET INTRO 
LOST DATA 
RESET BUSY 


YES 


TG43 UPDATE 


YES 


NO 


SET DRO 


DELAY 3 BYTE 
TIMES 


N0 
HAS 
DRO BEEN 
SERVICE 


YES 


INTRO 
RESET BUSY 


HAS 
INDEX 
PULSE 
OCCURED 


YES 


DR TO DSR 


SET DRO 


'30 MS IF CLOCK 
= 
1 MHI 


HAVE 6 
INDEX NOLES 
PASSED 
1 


NO 


HAS 
IDAM BEEN 
DETECTED 
1 


vES 
----Op 


SRIFT I BYTE 
INTO DSR 


TRANSFER 
BYTE TO DR 


SET DRO 


HAVE 6 
BYTES BEEN 
READ 


vES 


TRANSFER TRACK 
NUMBER TO SECTOR 
REGISTOR 


CRC 
ERROR 


NO 


READ ADDRESS 
SEQUENCE 


YES 
RESET SUSY 
SET HTRO 
SET RNF 


‘E5 
set cnc 
ERROR BIT 


SET INTRO 
RESET ausv 
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This sequence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears in the 
data register is written on the disk with a normal clock 
pattern. However, if the 279X detects a data pattern of F5 
thru FE in the data register, this is interpreted as data ad- 
dress marks with missing clocks or CRC generation. 


The CRC generator is initialized when any data byte from 
F8 to FE is-about to be transferred from the DR to the DSR 


CONTROL BYTES FOR INITIALIZATION 
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TYPE III COMMAND WRITE TRACK 


VE5 
(MIMI 


NOIFMI 


OOES 
YES 
wmyi 2 CRC 
° “ 
cums cu< 


D 
UO 
T“ U5 
F'- 
Q 
vi 


vs 
UT 


J 
J 


Z1'1Z 
‘T OO 
O" 


oozs 
YES 
wane rc 
D5" 
Cut 
or 


INITIALIZE CR 


ES 
v 
WRITE ED FE OR 


on re re 
C 
1 


WRITE DSR 
_ 
CLK 
FF 


'55 
PHYS 
INTRO RE$ET Busv 
INDEX MARK 


7 


I 
HAS 
wane 
0" B"~ 
Zliioiifigii 
LOADED 


YES 


-I 


YES 
WRITE AI'IN MFM 
WITH MISSING CLOCK 
INITIALIZE C 
C 


Z O 
T 


' 
S 
DOES 
DSR 
F5 


NO 


092$ 
vES 
wane c2: m um 
5 1" '5 
WITH MISSING ctocx 


NO 


DOES 
yes 
DSR 
H 
WRITE 2 CRC 


1 
CHARS 


NO 


WRITE DSR 
IN MFM 
T’ 


DATA PATTERN 
VL279X INTERPRETATION 
VL279X INTERPRETATION 
IN on (HEX) 
' 
IN FM (DDEN =1) 
g 
IN MFM(DDEN=0) 


__1_ 
00 thru F4 
Write00 thru F4 with CLK = FF 
Write00 thru F4, in MFM 
F5 
Not Allowed 
F6 
. 
Not Allowed 
F7 
' 
Generate 2 CRC bytes 


Write A1 * in MFM, Preset CRC 
Write C2“ in MFM 
Generate 2 CRC bytes 
F8 thru FB 
Write F8 thru FB, Clk = C7, Preset CRC 
| 
Write F8 thru FB, in MFM 
FC 
Write FC with Clk = D7 
FD 
Write FD with Clk = FF 


- 
Write FC in MFM 
Write FD in MFM 
FE 
Write FE, Clk = C7, Preset CRC 
Write FE in MFM 
FF 
I 
Write FF with Clk = FF 
g 
| 
WriteFFin MFM 
g 
’ Missing clock transition between bits 4 and 5 
L 


L_ 


L 
* * Missing clock transition between bits 3 and 4 
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or by receipt of F5 ln MFM. An F7 pattem will generate two 
CRC characters in FM or MFM. As a consequence, the 
patterns F5 thru FE must not appear in the gaps, data 
fields, or ID fields. Also, CRC’s must be generated by an F7 
pattem. 


Disks may be formatted in IBM 3740 or System 34 formats 
wlth sector lengths of 128, 256, 512, or 1024 bytes. 


TYPE IV COMMANDS 
The Forced interrupt command ls generally used to ter- 
minate a multiple sector read or write command or to in- 
sure Type I status in the status register. This command can 
be loaded into the command register at any time. If there is 
a current command under execution (busy status bit set) 


TYPE Ill COMMAND Read Track/Address 


5 


SET DUSY 
RESET STATUS 
BITS 2 
5 


INTRO 
RESET BUSY 


YES 


COPY S FLAG 
TO SSO LINE 
(2195 7 ONLYI 


SET HLD 


NO 


YES 


DELAY TSMS 


YES 


TG43 
UPDATE 


NO 


YES 
READ 
ADDRESS 


NO 
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the command will be terminated and the busy status bit 
reset. 


The lower four bits of the command determine the condi- 
tional interrupt as follows: 
I0 = Not-Ready to Ready Transition 
I1 = Ready to Not-Ready Transition 
'2 = Every Index Pulse 
I3 = Immediate Interrupt 
The conditional interrupt is enabled when the correspond- 
ing bit positions of the command (I3 - '0) are set to a 1. 
Then, when the condition for interrupt is met, the INTRO 
line will go high signifying that the condition specified has 
occurred. If I3 - I0 are all set to zero (HEX D0), no interrupt 
will occur but any command presently under execution will 
be immediately terminated. When using the immediate 


READ TRACK 
SEQUENCE 


YES 


smrr ONE BIT 
INTO DSR 


YES 
SET INTRO 
RESET ausv 


NO 


ADDRESS 
YES 
MARK DETECTED 
? 


No 
I 


mtve a 
I 
ans aesu 
ASSEMBLED 
? 
I 
vss 
4-—-ill 


SET LOST 
DATA BIT 
ZO 


YES 


TRANSFER 
DSR TO DR 


SET 
DRO 
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interrupt condition I3 = 1), an interrupt will be immediately 
generated and the current command terminated. Reading 
the status or writing to the command register will not auto- 
matically clear the interrupt. The HEX D0 is the only com- 
mand that will enable the immediate interrupt (HEX D8) 16 
clear on a subsequent load command register or read sta- 
tus register operation. Foliow a HEX D8 with D0 command. 


Wait 8 micro sec (double density) or 16 micro sec (single 
density) before issuing a new command after issuing a 
forced interrupt (times double when clock = 
1 MHz). 
Loading a new command sooner than this will nullify the 
forced interrupt. 


Forced interrupt stops any command at the end of an in- 
ternal micro-instruction and generates INTRO when the 
specified condition is met. Forced interrupt will wait until 
ALU 
operations 
in 
progress 
are 
complete 
(CRC 
calculations, compares, etc.) 
More than one condition may be set at a time. if for 
example, the READY TO NOT-READY condition (I1 = 1) 
.and the Every Index Pulse (I2 = 
1) are both set, the 
resultant command would be HEX “DA." The “OR” func- 
tion is performed so that either a READY TO NOT-READY 
or the next index Pulse will cause an interrupt condition. 
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STATUS REGISTER 
Upon receipt of any command, except the Force interrupt 
command, the Busy Status bit is set and the rest of the 
status bits are updated or cleared for the new command. if 
the Force Interrupt Command is received when there is a 
current command under execution, the Busy status bit is 
reset, and the rest of the status bits are unchanged.-if the 
Force interrupt command is received when there is not a 
current command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or cleared. 
In this case, Status reflects the Type I commands. 


The user has the option of reading the status register 
through program control or using the DRO line with DMA or 
interrupt methods. When the Data register is read the DRO 
bit in the status register and the DRO line are automatically 
reset. A write to the Data register also causes both DRO’s 
to reset. 
' 


The busy bit in the status may be monitored with a user 
program to determine when a command is complete, in lieu 
of using the INTRO line. When using the INTRO, a busy 
status check is not recommended because a read of the 
status register to determine the condition of busy will reset 
the INTRO line. 


The format of the Status Register is shown below: 


(BITS) 
' 
I 
__ 
_ 
I 
an _ _ 
7 
6 
5 u 
3 
2 
1 
0 
' 
S1 
S6 
$5 
S4 EEEI so 


Status varies according to the type of command executed 
as shown in Table 4. 


Because of internal sync cycles, certain time delays must 
be observed when operating under programmed IIO. They 
are: (times double when clock = 1 MHz) 


9 
I 
Delay Req d 
Operation 
Next Operation 
FM 
MFM 
1-it 
----_ 
—- 
I —--—--A-——N 
Write to 
Read Busy Bit 
12ps 
Gus 
Command Reg. 
(Status Bit 0) 
Write to 
Read Status 
28ps 
141.18 
Command Reg. 
Bits 1-7 
Write Any 
Read From Diff. 
0 
Register 
Register 


IBM 3740 FORMAT — 128 BYTESISECTOR 
Shown below is the IBM singiedensity format with 128 
byteslsector. in order to format a diskette, the user must 
issue the Write Track command, and load the data register 
with the following values. For every byte to be written, there 
is one Data Request. 


O 


- 
6 
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I 
NUMBER 
HEX VALUE OF 
OF BYTES 
BYTE WRITTEN 
40 
FF (or 00)3 
A 
6 
00 


1 
FC (index Mark) 
I 26 
FF (or 00) 
6 
00 


-A—A.-A-A-A-A 


FE (ID Address Mark) 
Track Number 
Side Number (00 or 01) 
Sector Number (1 thru 1A) 
00 (Sector Length) 
F7 (2 CRC’s written) 
11 
FF (or 00) 
00 
1 
128 


1 


FB (Data Address Mark) 
Data (IBM uses E5) 
F7 (2 CRC’s written) 
27 
FF (or 00) 
2472 
FF (or 00) 


1. Write bracketed field 26 times 
2. Continue writing until 279X interrupts out. 
Approx. 247 bytes. 
3. A ‘O0’ option is allowed . 


IBM SYSTEM 34 FORMAT- 
256 BYTESISECTOR 
Shown below is the IBM dual-density format with 256 
bytesisector. In order for format a diskette the user must 
issue the Write Track command and load the data register 
with the following values. For every byte to be written, there 
is one data request. 


IBM TRACK FORMAT 


/-i 
INDEI ADDRESSMARI 


6" 
ca" 
on I 
A1 
,0 
GAP I 
DATA 
cu T 
"E "I051 
a BYTES 
POST moi! 
J BYTES 
“co” 
I0 GAP 
FIELD 
DATA on 
IE BYTE Fl 
MFM 
11 BYTE FM 
MFM 
17 BYTES FM 
gicogo 
3 Qyfi Q. 
7“ ‘Tris "F" 
ONLY 
B? BYTES HEM 
ONLY 
no ' 
SI BYTE MFM 
no | 
a ayyl ‘pg 
NOMINAL 


I 


I 


ID 
SECTOR 
ADDRESS 


IN um ONLY i0Au AND DATA Au 
ARE PIIECEOED BY THREE BYTES Or 
AI WITN CIOCII TRANSITION BETWEEN 
BITS I AND 5 MISSING 
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— 
i______ 
__ 
_ 
__ 
M 
1 
HEX VALUE OF 
BYTE WRITTEN 


4E 
I- 


NUMBER 
OF BYTES 


To 


IO 


00 
F6 (Writes C2) 
FC (index Mark) 
4E 
00 
F5 (Writes A1) 
FE (ID Address Mark) 
Track Number (0 thru 4C) 
Side Number (0 or 1) 
Sector Number(1 thru 1A) 
01 (Sector Length) 
F7 (2 CRCs written) 
4E 
00 
F5 (Writes A1) 
FB (Data Address Mark) 
DATA 
F7 (2 CRCs written) 
4E 
54 
598' ' 
4E 


I 


* Write bracketed field 26 times 
' * Continue writing until 279X interrupts out. 
Approx. 598 bytes. 


ID 
DATA 
ID 
DATA FIE LD L . 
D 
DATA FIELD 
RECORD 
RECORD 
RECORD 
RECORD 
RECTD 
RECORD 
NO I 
NO I 
NO I 
NO I 
I 
NO. II 
NO. II 


DATA OI 
DELETED 
°‘““ 
051.5: 
ADDRESS 
IARI 


"MISSING CLock TRANsiTi0N 
BETWEEN BITS I AND A 


FM ‘oi u 
v 
—-c+- 
Y 
0 
IBYTE HQIYTES A 
9 


TBYTE 


I TES 
I I TES 


um 
" ""5 
j 
12 ewes 
1 


WRITE GATE TuRRi ON F00 UPDATE 
- 
or IIEIT DATA lino 
[ 
\ 
3 
i 
WRITE TURN O" IDA UPDATE 
O0 PIEVIOUB DATA Fl-ELD 
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1. NON-IBM FORMATS 
Variations in the IBM formats are possible to a limited ex- 
tent if the following requirements are met: 


1) Sector size must be 128, 256, 512 of 1024 bytes. 


2) Gap 2 cannot be varied from the IBM format. 


3) 3 bytes of A1 must be used in MFM. 


ln addition, the Index Address Mark is not required for 
operation by the 279X. Gap 1, 3, and 4 lengths can be as 
short as 2 bytes for 279X operation, however PLL lock up 
time, motor speed variation, write splice area, etc. will add 
more bytes to each gap to achieve proper operation. lt is 
recommended that the IBM format be used for highest 
system reliability. 


ELECTRICAL CHARACTERISTICS 


GAP 


Gap I 
Gap ll 


Q 


O 


Gap III“ 
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FM 
MFM 
I 
" 


16 bytes FF 
11 bytes FF 
6 bytes 00 


10 bytes FF 
4 bytes 00 


Iéi; 
32 bytes 4E 
22 bytes 4E 
12 bytes 00 
3 bytes A1 
24 bytes 4E 
8 bytes 00 
3 bytes A1 
Gap IV 
16 bytes FF 
16 bytes 4E 


' Byte counts must be exact. 
** Byte counts are minimum, except exactly 3 bytes of A1 
must be written. 


Absomte Maximum Ratings 
NOTE: Maximum limits indicate where permanent device 


Voltage to any input with 
damage occurs. Continuous operation at these limits is not 
respecuov 
_ +7“) _05V 
intended and should be limited to those conditions 
SS _ 
' 
specified in the DC Electrical characteristics. 
Operating temperature = 0°Cto 70°C 
Storage temperature = -55°C to + 125°C 


i 


$5 
i 
Ti 
OPERATING CHARACTERISTICS (DC) TA = 0°C to 70°C, V53 .-= 0V,V(;(; = + 5V + .25V 


. 
. 
F. . 
____T_ 
SYMBOL 
CHARACTERISTIC 
it 
1 
1 
MIN 
TYP 
MAX 
UNITS 
CONDITIONS 


Input Leakage 
Iii. 
lQ|_ 
Output Leakage 
V||-| 
Input High Voltage 
2.0 
V| L 
Input Low Voltage 
VQH 
Output High Voltage 
2.4 
VQL 
Output Low Voltage 
VOHP 
Output High PUMP 
2.2 
XOLP 
Output Low PUMP 
D 
Power Dissipation 
Rpu 
lntemal Pull-up‘ 
100 
ICC 
Supply Current 
70 
150 


10 
, 
pA 
— 
V|N = VCQ 
Vour = Vcc 


'@-5G1»0 


?_"§,2<<<<<<"§, 


I 


..i 
0.8 
T 


I 
IO = -100pA 
0.45 
I 
‘ 
10 = 1.6 mA 
IQP = -1.0 mA 


I 
IQP = +1.0 mA 
All Outputs Open 
1700 
V|N : OV 
All Outputs Open 


.__._____i___._.____._..______.___._..__._..__.___ 
’ Internal Pull-up resistors on PINS 1, 17, 19, 22, 36, 37 and 40. Also pin 25 on 2793. 


iiii 
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TIMING CHARACTERISTICS TA = 0°Cto 7o°c, vss = ov, vcc = +sv 1 .2sv 


READ ENABLE TIMING 


VL2793 - VL2797 


SYMBOL 
CHARACTERISTIC 
m 
TYP 
MAX 
UNITS 
i 
1 
N 
N 
TSET 
Setup ADDR & CS to RE 
THLD 
Hold ADDR & cs from R_E 
TRE 
- 
RE Pulse Width 
TDRR 
DRO Reset from ‘FE 
T|RR 
INTRO Reset from RE 
TDACC 
| 
Data Valid from R-E 
TDQH 
J Data Hold From fe 


WRITE ENABLE TIMING 


SYMBOL 
CHARACTERISTIC 


1__I___ 
1,11 
1 
E 
TSET 
Setup ADDR & CS to WE 
T|~|LD 
Hold ADDR & cs from ‘WE 
TWE 
_W_E Pulse Width 
TDRR 
DRO Reset fromWE 
T|RR 
INTRO Reset from WE 
TD3 
Data Setup to WE_ 
TD|-| _ 
g 
Data Hold from WE 


50 
10 
200 


20 


MIN 


100 
500 
100 


200 
3IX)O 
200 
150 


HSBC 


RSBC 


IISGC 


DSBC 


OSGC 


RSBC 


RSBC 


CONDITIONS 


C|_ = 50 DI 


See Note 
C|_ : 50 DI 
CL = 50 pf 


N 
I 
I 
UNITS 
CONDITIONS 
TYP 
MAX 


§a8 


150 
50 
HSGC 


A 
I 
1 
I"IS8C 


ITSGC 


ITSGC 


ITSGC 


RSGC 


I"I$8C 


100 
200 
500 
3000 
See Note 


READ ENABLE TIMING 
WRITE ENABLE TIMING 


—_—__ _. 
—_ 
-4 
I6 
OR 32' Us 
Ii! 
I 
-10 
T6‘ OR 
u5 
I-— Toma 
I~.—*om= 


VOH 


DRO 


TIMI‘ -SQ-I 


INT R0 
I 


-_-i 
‘SERVICE 


Iimr so-I 


NTRQ 


‘mo 
THLO 
vol 
‘SERVICE 
V Ii 


A0 A1 CS 
Wt 
_— (D 
A0 AI 
(_<. 
I 
-_— T RE 


W 
VIH 


‘set 
Ioacc |-- 
_ 
0 
' 


_ 
-4. 


N01! 
1 
CS an BE PERMANENTLV nEO LOW ir OEsmEO 
-TIME DOUBLES WHEN CLOCK 
" INN! 


1 SERVICE IWORST CASE! 
‘FM 
275 uS 
‘MFM 
I35 uS 


DRO RISING EDGEt INDICATES THAT THE DATA REGISTER HAS ASSEIIBLED 
OATA 
DRO FALLING EDGE: INDICATES THAT THE DATA REGISTER WAS READ 
INTRO RISING EDGE1 OCCURS AT END OF COMMAND 
INTRO FALLING EDGE: INDICATES THAT THE STATUS REGISTER WAS READ 


I 
-n--Ina 


TE 
UH 


‘sci 


[$1 
DATA UJST 
BE VALID 


I 
S 
‘ 
-1*» 
Tm 


NOTE I E; miv as PERIIANENTLY reo LOW IF oesneo 
2 mien wniriuo DATA mo secroa TRACK on oan 
REGISTER usea caimor new rms neoisrsa uum 
AT LEAST 4 “sec in uni AFTER we msino zoos or we 
!$““"¢E ""°"$* we 
¥"+§6‘r'3§'J8‘?~'?l°s3'§E°=3Ts'£E'?ii“§3'§I‘.'§§’E‘»§”3m 
93,? gss 
urea mess rues me oouanso wueu CLK 
i ll-1: - 
“ 
-mic oouetss wuen aocx 
mm 


one RISING zoos; moicares THAT mt DATA REGISTER is cum 
one ntuuc zoos; iuoicnes mu me mm aeoisrea is toaoeo 
mrno RISING woe; 
r r 
0 
INDCA E 
HE ENDOF ACXUAN 
lNT% 
FALLING EXE: 
INXATES 
THAT 
THE C$MAND 
IGISTER 
IS WRITTEN TO 
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INPUT DATA TIMING 


s7iviBOL 
"I 
CHARACTERISTIC 
_ “E 
“MIN 
I TYP 
iviAx 
LUNITS 
CLONDITIONS 
K 
Tpw 
Raw Read Pulse Width 
100 
200 
nsec 
TBQ 
Raw Read Cycle Time 
1500 
2000 
nsec 
t 
W 
1". 
ii 
M 
N 
7 
M’ 
J T 
Ti.” 
7 
' 
_ J11’ 7 
""' 


WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 
1 MHZ) (NO WRITE PRECOMPENSATION) 


SYMBOL 
CHARACTERISTIC 
H 
MIN T 
TYPE 
I 
I ivTAx 
UJNITSEI 
c§o~oiTio§is 


TWYQ 
L 
WriteDat—aPulseW_i-d-Ih 
H400 
1500 
600 
nse; 
FM 
200 
250 
300 
Two 


TWF 


Write Gate to Write Data 


Write Gate off from WD 


1 
r 
ii _ 


MISCELLANEOUS TIMING: 


2 


1 


-no 


DSBC 
pSBC 
pSBC 
yS8C 
pSBC 


MFM 
FM 
MFM 


' 
FM 
MFM 
I 
L 
r 
_ WT 
1 
—i_ 
jj 
I 
*’"1 


SYMBOL 


' 
Ii-Q’ 
Y 
M-Zipi 
‘H 
ing 
1 
1-Q-3 
_1-hL 
lII(T' 
1-I7’ 
f*’1’ 
ICD1 
ICD2 
ISTP 
IDIR 
IMR 
HP 
RWP 


WPW 


WPW 


VCO 


VCO 


VCO 


Cext 


RCLK 


Clock Duty (low) 
Clock Duty (high) 
Step Pulse Output 
Dir Setup to Step 
Master Reset Pulse Width 
Index Pulse Width 
Read Window Pulse Width 


CHARACTERISTIC “E 
' 
I W 
Mi'iTI__TvT5 
I 
IIIIAX 
'T1NiTs] 
CONDITIONS 
230 
250 


Precomp Adjust. 
Write Data Pulse Width 


Write Data Pulse Width 


Free Run Voltage Controlled 
Oscillator. Adjustable by ext. 
capacitor on Pin 26 
Pump Up + 25% 


Pump Down - 25% 


5% Change VCC 
TA = 75°C 
Adjustable external capacitor 


Derived read clock 
= VCO + 8, 16, 32 


PU/DON 
; 
PU/PD time on 


I 
I 
ILQC|>(' 
H 
g 
Data Separator CaptureRange 
K 
237.5 
~ 
250 
(pulse width) 


. 
20000 


I 
230 
250 
I 
20000 
2or4 
12 
50 
10 
I 


120 
700 
240 
‘I400 
100 
300 


200 
300 
400 


600 
‘ 
900 
1200 
6.0 
Q 
4.0 


5.0 


as 
, 
4.2 
3.5 
20 
45 
100 


‘5o0= 


250 
I 


250 


, 
125 


I 
250 


3.0 
‘ 


DSBC 
nsec 
pS€C 
pSBC 
pS8C 
pSBC 


DSBC 
DSBC 
nsec 


DSBC 


nsec 
MHz 
MHz 


MHz 


MHz 


MHz 
MHz 
pf 


KHz 


KHz 


KHz 


KHz 


ns 


See Note 


| 
x CLK ERROR 


See Note 


1- 
lnput05V 
MFM 
FM : 15% 
MFM 


F Precomp = 100 nsec 


~ 
MFM 
Precomp = 300 nsec 
FM 


I 
Cext = 0 
Cext = 35 pf 


PU =.- 2.2V 
CBXI == 35 pf 


I 
FD‘ = o.2v 
CBXI = 35 pf 
CBXI = 35 DI 
CBXI = 35 DI 


| 
VCO = 4.0MHZ 


- 
ROHI 
VCO = 4.0MHZ 


I 
DQEN=0 
5/8:1 
DEE-_I\_l=0 
5/8:0 
2i~T=1 


I 
518:1 


' 
Otq = 
1 
5/a=0 
MFM 


‘ 
, 
500 
ns 
, 
FM 
262.5 
kbits/sec 
5'/8 =~ 0 


' 
G 
*1 
‘The f|_QQ|< specification is guaranteed from 10°C to 40° C. 


_ 
I. 
_ 
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MISCELLANEOUS TIMING 
WRITE DATA TIMING 


‘P I-1____Il__‘ 
->I 
I<—TwP 
I-ti TIP 
I 
~—- 
w,,__I—I_..-..J—I____ 


*7’ Ii_i_’i———I 
——>i 
§<—-Twe 
I<—Twi= 
I 
I 
A 
I 
|.._ r... _..| 
wG__.I 
1 


3 r 
v»~ 


I-ti 
TMR —a-i 
READ DATA TIMING 


I-'=="=-I 
|<__iee--_>| 


'“I’°°~ 
' 
READ 
I 
I 
I 
I 
.. ,,,,, 
DATA 
_>| 
l‘_Tpw 


I 
I 
Ii. 


°"‘° 
I8? 
<-nine--> 
NQTES; 


I 
r,,,,_jr._,| 
__jr, 
|.__ 
|_r,, 
__| 
I 
1 
. 
" 
' 
’° “'* 
"’ 
"‘ 
’$"° ""' 
. Times double when clock = 1 MHz. 


I 
| 
I 
| 
I 
T 
| 
2. Output timing readings are at VQL = 0.8v and VQH = 


"' FROM STEP RATE TABLE 


TABLE 4. STATUS REGISTER SUMMARY 


ALL TYPE I 
BIT 
COMMANDS 
s1 
Nor READY 
S6 
WRITE 
PROTECT 
S5 
HEAD LOADED 
S4 
SEEK ERROR 
S3 
CRC ERROR 
S2 
TRACK 0 
S1 
INDEX PULSE 


READ 
ADDRESS 


NOT READY 
0 


0 
RNF 
CRC ERROR 
LOST DATA 
DRO 


RECORD TYPE 


CRC ERROR 
LOST DATA 


20v. 


READ 
READ 
WRITE 
SECTOR 
TRACK 
SECTOR 


NOT READY 
NOT READY 
NOT READY 
0 
WRITE 
PROTECT 
0 
0 
0 
RNF 
0 
CRC ERROR 
LOST DATA 
LOST DATA 
DRO 
DRO 


WRITE 
TRACK 


NOT READY 
WRITE 
PROTECT 
0 
0 
0 
LOST DATA 
DRO 
S0 
BUSY 
BUSY 
BUSY 
BUSY 
BUSY 
BUSY 


STATUS FOR TYPE I COMMANDS 


BIT NAIIAE I" 
MEANING 


‘S7-NOT REA_DY 
_ 
This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready 
This bit is an inverted copy of the Ready input and logically ‘ored' with MR. 


S6 PROTECTED 
S5-ITEEAD i.oAEEo 


S4 SEEK ERROR 
ssoac ERROR 
s2 TRACK 00 
—- 


s—o BUSY". 
I 
When set command 


When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input. 


When set,"it indicates the head is loaded and engaged. This bit is a logical “and” of HLD and HLT 
signals. 
“I 
E 
— 
When set, the desired track was not verified. This bit is reset to 0 when updated 


CRC encountered in ID field. 
_ 
H-I 
- 


When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the 
TROO input. 


S1 INDEX 
When set indicates index mark detected from drive. This bit is an Inverted copy of the IP Input 
progress. When reset no command is in progress. 
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STATUS FOR TYPE ll AND Ill COMMANDS 


" 
I 
**1_ " 
_:1___ 
_ 
__ 
_ 
_ 
BIT NAME 
MEANING 
g 
s7 NOT READY 


1 
1 
_ 
1__'1 
S6 WRITE PROTECT 


LThis bit when set indicates The drive islnot ready. T/Vhen resent: it indicates that thefdrive _isready. 
This bit is an inverted copy of the Fieady input and ‘ored’ with MR. The Type ll and Ill Commands 
will not execute unless the drive is ready. 


L_ 
___' 7” 
it 7' 
1 
pg? 
r 
—*7 
I_" 
__' ' 
__' ' 
7 
7 
On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write Protect. 
This bit is reset when updated. 
ss necono TYPE 


L '* 
I11 
'_ ’_ 
1'. 
1 "_' 
b-Z1 
7. 
_ 
'1 
___ 
' 
" 
_ I 
On Read Record: lt indicates the record-type code from data field address mark. 1 = Deleted 
Data Mark. 0 = Data Mark. On any Write: Forced to a Zero. 


L1" 
K7'7 
____ 
"7 
s4 RECORD NOT 
FOUND (RNF) 


____'f' 
"*'* 
__1' 1 
'_ 
L___ 
_ 
1 
_ 
’ 
I 
__ 
_J 
__ 
_ 
__ 
When set, it indicates that the desired track, sector, or side were not found. This bit is reset when 
updated. 
sa cac Enrich 
If S4 is set, an error is found in one or more ID fields; othenivise it indicates error in data field. This 
bit is reset when updated. 
g 7 
_ 
K 
_ 
g 
g 
s2 LOST DATA 
When set, it indicates the computer did not respond to DRO in one byte time. This bit is reset to 
§ero whenupdated. 
g 
i 
H 
H 
s1 oArA nsouesr 
This bit is a copy of the DRO output. When set, it indicates the DR is full on a Read Operation or 
the DR is empty on a Write operation. This bit is reset to zero when updated. 
g 
_ 
so ausv 
U 
When set, command is under execution. When reset, no command is under execution. 


__ 
T 
_lt_' 
**' 


SUMMARY OF ADJUSTMENT PROCEDURE 


WRITE PRECOMPENSATION 


1) 
Set TEST(Pin 22) to a logic high. 
2) 
Strobe Wt (Pin 19). 
3) 
Set TEST (Pin 22) to a logic low. 
4) 
Observe pulse width on WD (Pin 31). 
5) 
Adjust WPW (Pin 33) for desired pulse width (Precomp Value). 
6) 
Set TEST(Pin 22) to a logic high. 


DATA SEPARATOR 


1) 
Set TE‘? (Pin 22) to a logic high. 
2) 
Strobe W? (Pin 19). Insure that FT/8, and DDEN are set properly. 
3) 
set TEE? (Pin 22) to a logic low. 
4 
Observe Pulse Width on TG43 (Pin 29). 
5) 
Adjust RPW (Pin 18) for 1/8 of the read clock (250ns for 8" DD, 500ns for 51/4 " DD, etc.). 
6) 
Observe Frequency on DIRC (Pin 16). 
7) 
Adjust variable capacitor on VCO pin for Data Rate (500 KHz for8" DD, 250 KHz for 51/4 " DD, etc.). 
8) 
Set es? (Pin 22) to a logic high. 


NOTE: To maintain internal VCO operation, insure that TEST = 1 whenever a master reset pulse is applied. 
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FEATURES 
- Controls operation of 8K/16K/32K/64K 
dynamic RAMs 


- Creates static RAM appearance 


- One package contains address 
multiplexer, refresh control and timing 
control 


- Directly addresses and drives up to 
256K bytes of memory without external 
drivers 


~ Operates from microprocessor clock 


- Refresh may be internally or externally 
initiated 


- Strap-selected wait state generation 
for microprocessor/memory speed 
matching 


DYNAMIC RAM CONTROLLER 


- Three-state outputs allow multiport 
memory configuration 


- Performance ranges of 150 ns/200 
ns/250 ns 


~ Compatible with Tl TMS 4500A 


DESCRIPTION 
The VL4500A is a monolithic DRAM 
system controller designed to provide 
address multiplexing, timing, control, 
and refresh/access arbitration func- 
tions to simplify the interface of 
dynamic RAMs to microprocessor 
systems. 


The controller contains a 16-bit 
multiplexer that generates the address 


lines for the memory device from the 16 
system address bits and provides the 
strobe signals required by the memory to 
decode the address. An 8-bit refresh 
counter generates the 256-row ad- 
dresses required to refresh. 


A refresh timer is provided that gener- 
ates the necessary timing to refresh the 
dynamic memories and assure data 
retention. 


The VL4SO0A also contains refresh! 
access arbitration circuitry to resolve 
conflicts between memory access 
requests and memory refresh cycles. 
The VL450OA is offered in a 40-pin 600- 
mil dual-in-line plastic package and is 
guaranteed for operation from 0°C to 
70°C. 


PIN DIAGRAM 
BLOCK DIAGRAM 


CLK I 
RDY I 
REN1 I 
_¢3 I 
ALE I 
-RASO I 
-RAS1 I 
-ACR - 
-ACW - 
-CAS - 
RAO I 
CAO I 
MAO I 
MA1 I 
CA1 I 
HA1 I 
RA2 I 
CA2 I 
MA2 I 
GND I 


VL45ODA 


QM-l 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
16 
19 
20 


VCC 
-REFREO 
TWST 
FSO 
FS1 
RA7 
CA7 
MA7 
MA6 
CA6 
RA6 
RA5 
CA5 
MAS 
RA4 
CA4 
MA4 
RA3 
CA3 
MA3 


RNGRA7 


CAGCA7 


ALE 


REN1 


-ACR 
-AC“! 


-REFREO 


UNST 


8 
3 
ROW 
ADDRESS 
LATCH 
8 


3 
COLUMN 
ADDRESS 
LATCH 


REFRESH 
couurrzn 
I 


—CS 
llllllllllllllllllll 
SELECT 
““°" in 
"“s° 


MULTl- 
MAQ. 
PLEXER 
MA7 


-RAS1 


ARBITER 
TIMING 
AND 
-CAS 
CONTROL 


RDY 
REFRESH 
RATE 
GENERATOR 
FSO 
FS1 
I 


cu< 


QRDER INFORMATION 


Part 
. 
Access 
Number 
Time 
Package 


VL4500-15PC 
VL4500-1SCC Ceramic 


VL4500-20PC 
Plastic D 
VL4500-20CC 
Ceramic 


Note: Operating temperature range is 0°C 


1 77 


Plastic DIP 
DIP 


IP 
DIP 


to +70°C. 


PIN DESCRIPTIONS 


RAO-RA7 


CAO—CA7 


MAO-MA7 


input 
Input 
Output 


ALE 
Input 


C—S 
Input 


REN1 
Input 


ACR, ACW 
Input 


CLK 
Input 


REFREQ 
lnput/ 
Output 


RASO, RAS1 Output 


CAS 
Output 


RDY 
Output 


TWST 
Input 


FSO, FS1 
Inputs 
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Row Address — Used to generate the row address for the multiplexer. 
Column Address — Used to generate the column address for the multiplexer. 
Memory Address — 3-state outputs designed to drivethe addresses of the 
Dynamic RAM array. 
Address Latch Enable — Used to latch the 16 address inputs, TS and REN1. This also 
initiates an access cycle if Chip Select is valid. The rising edge (LOW-to-HIGH level) of 
ALE returns RAS to HIGH. 
Chip Select — A LOW on this input enables an access cycle. The trailing edge of ALE 
latches the Chip Select input. 
RAS Enable 1 — Used to select one of two banks of RAM via the IWSO and RAS1 
outputs when chip select is present. When LOW, RASO is selected; when HIGH, RAS1 is 
selected. 
Access Control, Read; Access Control, Write — A LOW on either of these inputs causes 
the column address to appear o_r@A0-MA7 and the Column Address Strobe to pulse 
Qe LOW. The risirlgidge of ACR or ACW terminates the cy_c_:_l_e_by iding RT\_Sid 
CAS strobes. When ACR and ACW are both LOW, MAO-MA7, RASO, RAS1, and CAS go 
into a high-impedance (floating) state. 
System Clock — Provides the master timing to generate refresh cycle timings and refresh 
rate. Refresh rate is determined by the TWST, FS1, FSO inputs. 


Refresh Request — (This input should be driven by an open-collector output.) On 
input, a LOW-going edge initiates a refresh cycle and will cause the internal refresh timer 
to be reset on the next falling edge of the CLK. As an output, a LOW-going edge signals 
an internal refresh reguest and that the refresh timer will be reset on the next LOW-going 
edge of CLK. REFREQ will remain LOW until the refresh cycle is in progress and the 
current refresh address is present on MAO-MA7. (Note: REFREO contains an internal 
pull-up resistor with a nominal resistance of 10 k.) 
Row Address Strobe — 3-state outputs used to latch the row address into the bank of 
DRAMs~selected by REN1. On refresh both signals are driven. 
Column Address Strobe — 3-state output used to latch the column address into the 
DRAM array. 
Ready — Totem-pole output used to synchronize memories that are too slow to 
guarantee microprocessor access time requirements. This output is also used to inhibit 
access cycles during refresh when in cycle-steal mode. 
Timing/Wait Strap — A HIGH on this input indicates a wait state should be added to each 
memory cycle. In addition, it is used in conjunction with FSO and FS1 to determine 
refresh rate and timing. 
Frequency Select 0; Frequency Select 1 — Strap inputs used to select Mode and 
Frequency of operation as shown in Table 1. 


178 


TABLE 1: 
STRAP CONFIGURATION 


gqi_ 


L 
L(1) 
L 
I 
H 
L 


IIII 
r-r" 
IIr-r-IIr-r- 


r-Ir-II 


Notes: 
1. This strap configuration resets the Refresh Timer circuitry. 
2. Upper figure in refresh frequency is the frequency produced if the minimum CLK frequency of the next select state is used. 
3. 
Refresh frequency if CLK frequency is 5 MHz. 
4. 
Refresh frequency if CLK frequency is 8 MHz. 


FUNCTIONAL DESCRIPTION 
VL4500A consists of six basic 
blocks; address and select latches, 
refresh rate generator, refresh 
counter, the multiplexer, the arbiter, 
and the timing and control block. 


ADDRESS AND SELECT 
LATCHES 
The address and select latches 
allow the DRAM controller to be 
used in systems that multiplex 
address and data on the same lines 
without external latches. The row 
address latches are transparent, 
meaning that while ALE is HIGH, 
the output at MAO-MA7 follows the 
inputs RAO-RA7. 


REFRESH RATE GENERATOR 
The refresh rate generator is a 
counter that indicates to the arbiter 
that it is time for a refresh cycle. The 
counter divides the clock frequency 
according to the configuration 
straps as shown in Table 1. The 
counter is reset when a refresh 
cycle is requested or when TWST, 
FS1 and FSO are LOW. The 
configuration straps allow the 
matching of memories to the system 
access time. 


Wait 
States 
Strap input Modes 
I 
For 
Minimum 
Memory 
Refresh 
Clk Freq 
Refresh 
TWST 
FS1 
FSO 
Access 
Rate 
Mi-I2) 
Freq kHz 
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0 
External 
— 
0 
Clk + 31 
1.984 
Clk + 46 
2.944 
Clk -:— 61 
3.904 
cut + 4e 
2.944 
cut + e1 
3.904 
cut + we 
4.ae4 
cm + 91 
I 
s.a24 
-5-L-L-A 
QQ 


Upon power-up it is necessary to 
provide a reset signal by driving all 
three straps to the controller LOW 
to initialize internal counters. A 
system's LOW-active, power-on 
reset (RESET) can be used to 
accomplish this by connecting it to 
those straps that are desired HIGH 
during operation. During this reset 
period, at least four clock cycles 
should occur. 


REFRESH COUNTER 
The refresh counter contains the 
address of the rowto be refreshed. 
The counter is decremented after 
each refresh cycle. [A LOW-to- 
HIGH transition on TWST sets the 
refresh counter to FF1e (25510).| 
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Clock 
Cycles 
For Each 
Refresh 
Refreq. 
4 
64-95 (2) 
64-85 (2) 
64-82 (3) 
e4-as <2) 
I 
e4-so <2) 
64-17 <2) 
64-as (4) 
Jiébbb#0060 


MULTIPLEXER 
The multiplexer provides the 
DRAM array with row, column, 
and refresh addresses at the 
proper times. its inputs are the 
address latches and the refresh 
counter. The outputs provide up 
to 16 multiplexed addresses on 
eight lines. 


ARBITER 
The arbiter provides two operational 
cycles; access and refresh. The 
arbiter resolves conflicts between 
cycle requests and cycles in 
execution, and schedules the 
inhibited cycle when used in cycle- 
steal mode. 


TIMING AND 
CONTROL BLOCK 
The timing and control block 
executes the operational cycle at 
the request of the arbitzilt prot/i_d<;:-_s 
the DRAM array with RAS and CAS 
signals. it provides the CPU with a 
RDY signal. It controls the 
multiplexer during all cycles. It 
resets the refresh rate generator and 
decrements the refresh counter 
during refresh cycles. 
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I 
I 
I 
" 
- 
- 


ABSOLUTE MAXIMUM RATINGS 


VL4500A 


Operating Ambient 
Stresses above those listed under 
above those listed on the 
Temperature Henge 
0°C I0 +70°C 
“Absolute Maximum Ratings" may 
operational sections of this 
Storage Temperature 
cause permanent damage to the 
specification is not implied and 
R8098 
-55° C I0 +150° C 
device. These are stress ratings only. 
exposure to absolute maximum 
Supply Voltage 
Functional operation of this device 
rating conditions for extended 
Range. Vcc, Note 1 
-1.5 to +7 V 
at these or any other conditions 
periods may affect device reliability. 
Input Voltage Range 
(any input), Note 1 
-1.5 to +7 V 
Continuous Power 
Dissipation 
1.2 W 


DC CHARACTERISTICS: TA = 0°C to +70°C 


Conditions 
' 
VIL (except Tm"E0)! input LOW Voltage 
-1.012) 
I 
.,_ 
E” 
"I 
Jr 
_' 
1 
r*|-I 
I 
I I 
o.e 
v 


v||_ (REFREQ) 
Input LOW Voltage 
I 
-1.012) 


_I 
I 
0.8 
V 
j~_1_ 
' 
1, 
__' 
____*I 
r-Ign-F*‘Il-I 
_ 
_ I 
I 
Input HIGH Voltage 
' 
2.4 
VIH 
6.0 
V 


_ 
_____ 
__1-r 
__f1 
' 
7’ 


I ‘Output LOW Voltage 
VoL 
0.4 
V 
IOL = 4 mA 
Vcc = 4.5 V 


_ 
"I 
Output HIGH 
MAO-MA7.RDY 
“U 
. 


Symbol 
g 
Parameter 
T 
K 
j 
Min +Typ gMax 
Unltr 


T 
l 


24 
V 
._ 
tr 
OH 
V°"a9e 
RASO,RAS1,CAS 
L 
2.7 


i 
REFREQ 
2.4 


6 
* 
V 
I01-|==—1mA 
Vcc=4.5V 


_ 
L 
W 
_ 
I0)-l=—100pAV¢¢=4.5V 


I 
_ 
_ 
_'_4 
" 
Input HIGH 
If 


I Current 
All pins except REFREQ 


IIH 
)uA 
Vl =5.5 V 
10 


‘-1.25 
mA “I 
—- 
~ 
Vl=0V 
T 
I 
' Input Low 
REFREQ 
[IT 
T 
IL 
' 
- 


I Current 
All others 


__I-I’ 
loz 
7 I Output O.-ff-State Current 
CS_ 
-1° 
I150 
Vo=0to4.5VVcc=5.5V 


E 
C 
Operat-Mrg SupplyCurrent 
_-“A 
lcc 
100 
140 
mA 
TA =0°C 
VCC-'—'5.5V 


_ 
LITI 
1 
I 
I 
I_ 
Ii 
I-III‘:-—-_ I 
1 
I 
1*; 


CAPACITANCE: 1",, = 25°C, r= 1.0 MHz 


-Symbol Paramefer 
l __ 
_ 
_ 
P Iilvlin 
Typ (3) 
Max 
Unit 
Condlfioh? 
I 
n 
l 
T 
Cl 
Input Capacitance‘ 
_ 
T 
I 
pF 
V1 = 0 V 
f 5 1 MHz 


Co 
Oetput Capacitance; 
T 
:_ 
A 
I 
6 
pF 
V0 é 0 VI 
f=1 MHz 


Notes: 
1. Voltage values are with respect to the ground terminal. 
2. The algebraic convention, where the more negative limit is designated as minimum, is used in this data sheet for logic voltage levels only. 
3. All typical values are at Vcc = 5 V. TA = 25°C except where otherwise noted. 
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AC CHARACTERISTICS: 1'), = 0° c to +10" c, vcc = s v 1- 10% 


VL4500A 15 
VL4500A 20 
VL4500A 


Symbol 
Parameter 
Unit 
Iclc) 
CLK Cycle Time 
0 


twig)-|-I F‘ 
‘CLK HIGH PuTse Width. 
twlcu 
CLK LOW Pulse Width 
Iii 
Transition Time, All inputs 


1 
1 
tAEL-CL 
Time Delay, ALE LOW IO 
CLK Starting LOW, Note 1 


tC|__-AE|_ 
TIITIG Delay, CLK LQW t0 
ALE Starting LOW, Note 1 


t¢L-AEH 
Time Delay, CLK LOW to 
ALE Starting HIGH, Note 2 


tw(AEH) 
PUISG Width ALE HIGH 
RS 


tAv-AEL 
‘llne Delay, Address, REN1, 
CS Valid to ALE LOW 


IAEL-"A)( 
TIITIB DBIGY ALE LQW IO 
Address Not Valid 


1AE|_-ACL 
Time DGIHY, ALE LOW IO 
th(RA) + 30 
I 
Ihtgm + 40 
II-NQA) 'I' 50 
ACX LOW, NOIGS 3, 4, 5, 6 


1 
I 


-5 


A 
-5 


atO 
8 


-A-5-5OQO 


-5 


_A_A 
AOOI 


I 
U‘! 


tAgH-C'L 
Time Delay, ACX HIGH to 
CLK LOW, Notes 3, 7 


IA(;|_-(;H 
Time Delay, ACX LOW 10 
CLK Starting HIGH (to 
remove RDY) 


tRQL-C|_ 
Time Delay, REFREQ LOW 
to CLK Starting LOW, Note 8 


tw(RQL) 
Pulse Width, REFREQ LOW 


I 


Notes: 
1. Coincidence of the trailing edge of CLK and the trailing edge of ALE should be avoided, as the refresh/access occurs on the trailing CLK 
edge. A trailing edge of CLK should occur during the interval from ITO“)? HIGH to ALE LOW. 
2. 
If ALE rises before AiC)( and a refresh request is present, the falling edge of CLK after tc|_-AER will output the refresh address to MAO-MA7 
and initiate a refresh cycle. 
3. These specifications relate to system timing and do not directly reflect device performance. 
4. 
On the access grant cycle following refresh, the occurrence of OAS LOW depends on the relative occurrence of ALE LOW to A'C—)'(' LOW. If 
»§ occurs prior to or coincident with ALE then CTS is timed from the CLK HIGH transition that causes RAS LOW. If AC3? occurs 20 ns or 
more after ALE then 6/E is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW. 
5. 
For maximum speed access (internal delays on both access and access grant cycles), A5)? should occur prior to or coincident with ALE. 
6. 
th(RA) is the dynamic memory row address hold time. TC_X' should follow ALE by IAEL-CEL in 8)/Stems Where the teqtltted thtnm is Qteetet the" 
IREL-MAX minimum. 
7. 
Minimum of 20 ns is specified to ensure arbitration will occur on falling CLK edge. IACH-CL also affects precharge time such that the 
minimum moi-£5 should be equal or greater than: tw(RH]'tw(CL) + 30 ns (for cycle where /TC)? HIGH occurs prior to ALE HIGH) where tw(RH) 
is the DRAM RAS precharge time. 
' 
8. This parameter is necessary only if refresh arbitration is to occur on this falling edge of CLK (in systems where refresh is synchronized to 
external events). 
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AC CHARACTERISTICS: TA = 0°c to +10°c, v 
= 5 v + 10% 
. 
_. 
_._..___.._____.____.___°‘? 
— 
__ 


tAEL-REL 
Time Delay, ALE LOW to RAS Starting LOW 
Symbol 
Parameter 
I Min 
[ Max 
Min 
Max 
Min 
I 
35 
40 
, 


VL4500A-15 
VL4500A-20 
VL4500A-25 
_i Max 


‘ '50 


1 
___ 
__L_II:’ 
i_'_l__*l 
l 
I 
I 
I 
It (REL) _ 
I 
15 
___L._ 


I 
1 
I 
1 
20; 
I25 
I 
IRAV-MAV 
) Time Delay, Row Address VaIidTt5U_ 
I 
I 
Memory Address Valid 
I 
___ 
45 
I 


IAEH-MAV 
TimeDelay, ALE HIGH to Valid 
Memory Address 
65 


tAEL-RYL 
Time Delay, ALE to RDY Starting LOW 
I 
_ 
| lr_w_sT = 1 or Refresh in Progress) 
40' 


IAEL-CEL 
I Time Delay, ALE LOW to CAS S-Tarting 
LOW, Note 9 


IAEH—REH 
HIGH 
ti ,M,,v,J_ Address Transition TTn‘e_T 
| 
I 
20 


Time Delay, ALEIHIGH to RAS Starting 
I 
30 
30 


4| 


50 
60 


75 
90“ 


40 
—_ 


I50 
I150 
70 
200 
so 


._._..40 . 


250 


I 
40 _ 


20 
|.25. 


IACL-MAX 
Row Address Hold from ACX LOW 


_ 
_____I— 
IIIIII-I11 
I’ 
_ 
in 
III’ 
1 
I 
i 


I 
I’ 
_I'I 
1 
III 
1 
I 
I 
H 
1 


u 
s 
15 
I 
20 
25 
, 


IMAV-CEL 
- Tlme Delay, Memory Address Valid to 
0 
0 
I 
0 
I 


W I 
CAS Starting LOW 


ttllclzu 


___L_ 
_"" 
""II—'_'_"_'nI 
L 
' iii 
I 


JI 


I 


__ 
R. 
_'_r'* 
1 
I 
I 
I 
I 
Time Delay, ACX LOW to CAS Starting 
LOW, Note 9 
IACL-CEL 


5' 
Time oela'yiAcxto"RAs Starting HIGH 
30 
' 
' 
.Ij*.°H"I?.§_'? 


CAS FallTime 
_ 
i 
, 
15 
I 
20 
' 
25 
A 
40 
100 L45 
130 
50 
I 
155 


I 


RAS Rise Time 
T 
ti (REHI 
15_| 
40. 
501 


1 
20' 
tAcR-can 


I 
“L_ 
____ 
1__4| I 
I 
I 
I 
I 
Time Delay, ACX HIGH to CAS Starting 
I 
5 
HIGH 
" 
I 
_I__ 
I 
IIQII 
l_ 
I 


30) 


471.1 
_I-I f—T 
7177 
10 
40 
15 
25, 


J 


50‘ 


ti ,CEH,_ 
I CAS Rise Time 
I 


1'3-I 
39 
tACH—MA_)(__COlUmn Address Hold ir9_r_n_Acx HIGH 
Y 
10 
_ 


J-UJ 


tci-l-RYH 
Time Delay, CLK HIGH to RDY Starting 
HIGH (After ACX LOW), Note 10 
. 
40 
“_1'5""' 
35' 
45’ 
I 
15 


I 
A 
_I’__"'I45_T_fI— 
‘I 
.50; 


IRFL-RFL 
l Time Delay-,“REFFTEQTE'xtertnal Until 
_ I T“ 


ICH-RFL 
1 Time Delay. CLK HIGH Until REFREQ 
I 


I Internal Starting LOW 
, 
Time Delay, CLK LOW Until Refresh 
T T 
Address gt/_a_I_id 
jg 


ICL-MAV 


ICH-RRL 
I Time Delay, CLK HIGH Until Refresh 
10 
I 
RAS Starting LOW 
. 


‘ Supported by REFREQI_nternal 
_ 
I 
30' 
I35 
H 
35’ 


TI 
"_'_"_"50 


I 
30 


T7?" 


35 


J 


l 
45‘ 


1 
1 
I I 
100 
, 
‘I 
.l.. 
T25 J 


A 
115' 
so 
20 
.....80.. 


'i'i""""'1 
tMAv-RRL 
I 
_. 
. 
. ._.___._.___i____,__.___ ... 
Time Delay, Refresh Address Valid 
I 
5 


1 
l 
F 
5 
I 
I 
5 
l 
untiigeiresn RAS LOW 
I 
. 
- 
I 


l 
I 
I 


t¢L-nr=n 
I Time Delay, CLK LOW to REFREQ ' T‘ T 
I 
I 


| Starting HIGH (3-cycle Refresh) 
50 
_ 
' 
55 
I 
75 
= 


1CH—RFH 
. Time Delay, CLK HIGH to REFREQ 
A 
Starting HIGH (4-cycle Refresh) 
1 
‘ 
50‘ 
I55 
I75 


- 
L 


I 
T 


ICH-RRH 
iTimeDelay.CLKHlGHtoRefresh'RAS 
" 
5 
35 
10 
45l 
10 
_L 
Starting HIGH 
T 
I 
I 
50.1 


ICH-MAX 
I 
l 
Time Delay, Refresh Address Hold 
-15 
, 
20 
25 
I 


1 After CLK HIGH 
I 
1 


Notes: 
9. 
The falling edge of CAS occurs as soon as both 1AEL—CEL and tAcL-cEL have elapsed. If ACX goes LOW prior to UAEL-CELI - IIACL-CEL) after 
ALE. the CAS timing is determined by tAEL-cEL. Otherwise. the access time increases, and the falling edge of CAS is measured from the 
falling edge of ACX instead of ALE (tAcL-cEL determines CAS timing). 


gonditlons 
l 
_ 


CL =160 pF 


' 
_CL=40pF___ 


k 
I 
1 
I 
1 
1 I 


I 
Cl,=160 pF 


CL = 320lpF 


CL =160 pF 


[jEt=ssspr; Q 
CL =160 p_F 


I 
CL =40 pF 


CL =160 pF 


10. RDY returns HIGH on the rising edge of CLK. If TWST = 0, then on an access grant cycle RDY goes HIGH on the same edge that causes 
access RAS LOW. If TWST -= 1, then RDY goes to the HIGH level on the first rising CLK edge after ACX goes LOW on access cycles and on 
the next rising edge after the edge that causes access RAS LOW on access grant cycles (assuming ACX LOW). 
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VLSI TECHNOLOGY, mc. 
VL4500A 


AC CHARACTERISTICS: TA = 0° c to +-10° c, vcc = s vi 10% 


Symbol 


tcH-REL 


1 
in 
it 
r 
in 
I 
*7, 1 
I-1:_*l 
' 
ya,’ 
_ 
i 
I-0‘ 
Z 
1 
VL450OA:15 
VL4500A-20 
VL4500A-25 
Parameter 
‘Min 
' Max 
Min 
Max h—Min 
' Max 
Unit 
Condltlons 
Time DeTay, cLKT-Tc:-I Until Access u 
F 
I“ I 
so 
K 
Z 
1 )0 
I 
I 
95 
I 
U 
5 
1 


11. 
1 
Starting LOW 
g 
i 
tCL-CEL 


iCL—MAX 
f 


but 
_ 
ii 7 
1 
i 
Time Delay, CLK LOW to Access CAS 
Starting LOW, Note 11 


i 
E 
125 
140 


I7 
F 


-i 
185 


Flow Address_Hold A1151 CLK |_ow_ 


in 
2s 
T 
1 
E301 
“Z 


17 


i 
40 


IL__ 


fwmcu 
K56 LOW-_Width, N01; 12 
H 
“H 


J 
1 116“ 
F405 


I7 


1 


—_ 
175 
if 


1 
I 


lREL—MAX 
151011) Address Hold FTOTTI RAS Low 


7! 
I 
'_L 
_‘i-ii! 
DC7 1 _ 


1 
35 


_ 


i 


ltinvu 
REY Fall WE 
O1 


T-T 
25 
so 
‘ 
it 
. ii 
10 
i 


‘l—$__ 
' 
I 
K20 


"1' 


FEYH’ 
RDY Rise Time _ 
_ 


I 
3-I. 
I 
7 
I 
-1 


_..L 
. 
29., 
_l 


IE 
l_ 
-i 


1 


1 
'55 i 
ELS 
Output Disable Time (3-state Outputs) 


i 


1u 
1‘ 
100 
1 
L,‘ _ i_ 
1 
L 
165 


IAEH-MAX 


ten 


Column Address Hold From ALE HIGH 
10 
15 
201 


' 
_____ 
i1 
r 
_ 
Output Enable Time (3-state Outputs) 


I 
-'~ 
"J 
s 
1 


A 
75 


— 
~w 


77 
I- 
105 


Til 


1CAV—CEL 


'1 
__ 
1 
Column Address Setup to CAS After 
Refresh 


T 
or 
F 
0 
0 
F 
0 


T 
“T 


I 


__l 


J 
I 


tCH—CEL 


_ 
_ 
_ 
_ 
__ 
_ 
Time Delay, CLK HIGH to Access 
CAS Starting LOW, Note 11 


1-It 
5.1801 
5'‘ 
200 


l_- 


1 


i 


i 
235 
i 


tACL:CL 


1 


_r_ 
___ 
_ 
_ 
77 
_ _ _ 
_ __l 
IT 
ACX LOW to CLK Starting LOW. Note 13 
25 
A 
as 


17 
451 


TACL-RYH 


_____ 
__ 
___ 
"iii 
l__ 
____ 
L 
ACX LOW to RDY Starting HIGH, Note 13 
‘40 
' 
C 
.i~ 
~ 
A 
‘ 


I7 
1 


J 
60 
\ 
1 


J 
iCL—ACL “cm LOW toACX Starting LOW,—i;lote 13 


'I_ 
_ 
___,_ 
Ti 
O 
' 
O 
____ 
_ 
__t 


1L 


1 
0 


I 


-u-I 


Cl, ==-160 pF 


CL =40 pF 


l 


CL =16O pF 


CL=40 pF 


Notes: 
11. 


_l_ 


On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. 
If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 
ns or more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW. 
12. 
The specification of tw (ACL) is designed to allow a CAS pulse. This assures normal operation of the device in testing and system 
operation. 
For RDY HIGH transition (during normal access) to be timed from the rising edge of CLK, ACX must occur ICL-ACl_ after the falling edge 
13. 
of CLK. For ACX prior to the falling edge of CLK by tAcL-cL. the RDY HIGH transition will be tAcL-mm. Note that 1ACL—Cl_ is a limiting 
parameter for control of RDY to be dependent on ACX LOW. During the interval for IACL-CL < MINIMUM to ICL-ACL > MINIMUM. the 
control of RDY may vary between the rising clock edge or falling edge of ACX. 


LOAD CIRCUIT 
AC TESTING INPUT, OUTPUT WAVEFORM 


OUTPUT 


'cL INCLUDES JIG CAPACITANCE 
and 0.8 V 101' 8 logic “O” 


V°¢ 
3.0 v 


"L 


2.4 V 
2.4 V 
‘\\\\ 
//’/' 
1159 1; 
TEST POINTS 


o.a v 
/ 
N 
0.8 v 
1 
o v 
""95" T55‘ 
meur 
ou"rr=ur 


AC testing inputs are driven at 3.0 V for a logic “1" and 
1-" 
0.0 V for a logic 
Timing measurements are made at 
2.2 V for a logic “1" and 0.6 V for a logic “O” at the 
outputs. The inputs are measured at 2.4 V for a logic “1" 
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® VLSI TECHNOLOGYI mc. 
VL4500A 
TIMING DIAGRAMS 
ACCESS cvcua TIMING 
<------ Icic) 


°“‘ 
IcL-Act. 
'W(¢L) 
' 


\‘<--—- Iwugp-|)ib 
—>~ 
If 
--> 
If 
CL AEH 


IVIICH) 


ALE 
1 


sari 
0163101»¢I§I§I¢I9I§I§I¢Z¢I9I¢I§I§I¢I§I9Z¢I§I¢I§I¢19191019101916”It 


*< 
1 - !vv(AcL)* 
s 
* 
<--—--—— last-Act. 
“*4 
fact-cu -—-—>i 
~<— More-ct 


AT 
‘ 


1 
‘ 
iltinzu 
I 
' 
i 
Itinzu) 
. 
<—— IAEL-REL 
ACH-REI-I—T<i>-* 


1 
1 
I 
**—"' IAEH-REH -—> 


RAS 
I 
1 


I 
|<— Inav-luv —> 
» 
A 
j+-—- hen-Max —>J 
__1___._>. 
I 
<-i--hen-MAV 
IACL-MAX 
i 
'<—>r— hicu-MA: 


I¢I§I¢I§I§I§Z§I§l'§I4I> 
' 
01¢)'6161016101910‘ 


1 
Ilvlav-cEl. 
F‘ 
I 
Illczrl) 
IIWAV) 
\-+— 
-<——;lnEL-MA):-é> 
i" 
Iticst) 
~<—IAcu-can 


CAS 
A 
i 
“mi \AcL-cstm 
IAEL RYL 
[Cg y“ 


RDY 
1 


Iugyu 
i. 
'I(RYH) 


»< 
~ 
A 
last ca 
E 
as 
E 
> 


REFRESH REQUEST TIMING 


1 
tact-ct 
i 
*<i--—-—--Di 
‘ 
6 
‘l 
<— lcn-an. 
(EXTERNAL) 
S 
lwinou 
it 
~<—i Inrt-art.-—~i> 
REPREO 
1 
(INTERNAL) 
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VLSI TECHNOLOGY, INC. 
VL4500A 


TIMING DIAGRAMS (C0nt.) 
OUTPUT 3-sure TIMING 


E()=mT) 


<—i——— Idis 
Ien 
* 
t 


I610101016IQIOIQIQIOIQIQIQIQIOE>T111 
T111 IDIQIQIQIQIQIOIQI 


REFRESH CYCLE TIMING (3-CYCLE) 


CLK 
I 


I 
ICL-RFH - 


ii} 
REFREQ 


I 


I 


I 
1 


I 
i‘<ii>Ti—- ICL-MAv 
<——>*— ICH-MAX 
1 
"- ICL-MAXI 


MAO-MA7 
I 
REFRESH ADDRESS 
I 
now Aooness 
I‘ 


<—-—> — ‘cu-am 
<——>-— lcu-arm 
<———> —- ‘cu-act 
lcnv-cu <———>~— 


RAS 


1 
I 


‘j<—-—- lmv-Rm -—>I 
"<~ lct-c£t1—> 


CAS 
\ 


l‘<——*'i—'i I(;H-¢£|_I -i—'——->7 


REFRESH CYCLE TIMING (4-CYCLE) 


I 


CLK 


I 
I 


I 
‘cu-am - 


REFREQ 
I 


I 
I 


i<-——>-'— t¢L.,Mv 
IcH-MAX —--<—->' 
ICL-MAXI — 


MAO-MA7 
REFRESH ADDRESS 
ROW AODRESS 
1 
’( 


— ‘cu-ant 
icu-nan — |<-">1 
‘CH-REL_‘1 


I 
I 
Icav-ca. 


I 


I 
RAS 


f"— lumv-Rat 
j*—IcL-cEl.I 


CAS 
~<—--i— Icu-ccti 


‘The voltage levels (on a RAS or CAS pin) used for testing tpls and ten are at 10% and 90% of the VOH-VOL range for that pin. 
’rOn the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. If 
ACX occurs prior_to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 ns or 
more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW. 
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VLSI TECHNOLOGYI mc. 
VL4500A 


TIMING DIAGRAMS (C0nt.) 
TYPICAL ACCESS/REFRESH/ACCESS cvcuz (3-cvcuz, rwsr = 0) 


I 
ACCESS 
1, 
REFRESH/ACCESS GRANT 
ACCESS 


I 
1 
I 
2 
I 
3 
1 
I 
W1 
W3 
2 
3 
1 
\ 
2 
I 
3 
1 
2 


CLK 


I 
1 


I 
I 
‘ 
I 
1 


I 
‘ 
I 
‘I 


1‘ 
I 
I 
1 


ma 
\ 
/ 
\ 
‘ 
/ 
\ 
/ 
\ 


I 
1 
i~ 
I 
I 
I 


1 
ii 
I 


I m%0%10@O@ 


I 
‘I 
1 
I 
‘ 
I 
I 
‘ 
I 
I 
I 


1‘ 
‘ 
I 
I 
‘ 


CAS 
\ 
/ 
» 
\ 
I 
/ 
I 
‘ 
\ 
/ 
I 
\ 


‘T 
I 
I 
y 
\ 
1 
‘ 
V 
I 


I 
I 
I 
1 
. 
.I 
I 


aov 
i 
\ 
‘ 
/ 
I 
1 
I 
I 


TYPICAL ACCESS/REFRESH/ACCESS CYCLE (4-CYCLE, TWST = 0) 


1 
ACCESS 
y 
REFRESH/ACCESS cmwr 


1 
2 
a 
4 
1 
1 
w 
w 
I 
w 
~ 
2 
a 
4 
1 
2 


I 


cut 
I 
y 
I 
\ 
1 


I 
‘ 
I 


ALE 
I 
I 
1 
I 
I 
I 
‘ 


I 
I 


ACX 
\ 
\ 
/ 
\ 
__ 
A 
/ 
I 
L 
I 


I 
‘ 
I 
I 
I 


\ O 
\ 
/ 
\ 
A 
/‘T’N 
I 
/—\ 


I 
I‘ 
I 
‘ 
M 
‘ 
CAS 
\ 
I 
A 
/ 
\ 
H 
\ 
/ 
\ 


I 
I 


israeo 
“ 
/ 
I 
I 
I 
I 


I 
I 
I 
I 
1 
1 
I 


I 
I 
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® VLSI TECHNOLOGY} INC. 
VL4500A 
TIMING DIAGRAMS (Cont.) 
TYPICAL ACCESS/REFRESH/ACCESS cvcus (3-cvcuz, TWST = 1) 


ACCESS 
REFRESH/ACCESS GRANT 
1 


1 
W1 
2 
3 
1 
W1 
W; 
W1 
2 
3 
1 
W3 
2 


cut 
I 
1 
1 
1 
*1 
1 
1 


I 
I 
1 
1 
~11/\ 
/\ 
I/x111 


1 
I 


I 


I 
I 


@@0@¢%m 


I 
I 


lmi 
\ 
/ 
\ 
I1 
/ 
I 
\ 
I: 
/ 
\ 


I 
I 
II 


1 
1 
1 
1 


aov 
\ 
I 
/ 
I 
\ 
I 
I 
/ 
I 
\ 
I 
/ 


TYPICAL ACCESS/REFRESH/ACCESS CYCLE (4-CYCLE, TWST = 1) 


ACCESS 
REFRESH/ACCESS GRANT 
I 


1 
‘ 
W1 
2 
3 
4 
1 
‘ 
W1 
W3 
W; 
W4 
2 
3 
4 
A 
1 
A 
, 
r 


* 
I 
E 
\ 
~ 
1 
/ 
\ 
/ 
I 


1 
1 


I 
I 
‘ 
1 


I 
11 
ib» 


1 
I 
I 


\1———————-/ 
I 
I 
L—-—/ 
i 
\-——-—-————' 
I 


1 
1 
I 


if \\\\\\\\\\\\\\\\ 
1 
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® VLSI TECHNOLOGY, mc. 
VL4500A 


READY (RDY) SIGNAL TIMING (WAIT STATE OPERATION, TWST = 1) 


CLK J 


i 
ALE 


RDY starting HIGH is timed from ACX LOW (tAcL-RYHi for the condition ACX going LOW while CLK HIGH. 


CLK 


ALE 
‘CL-ACL 


‘CH-RYH —>- -ii 
KCY 
i 


RDY 


RDY starting HIGH is timed from CLK HIGH (t¢|-|_nYH) for the condition ACX going LOW while CLK LOW. 
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VLSI TECHNOLOGY, mc. 


TYPICAL APPLICATIONS 
VL4500A 


68000 CPU TO VL4500A 128K X 16 MEMORY INTERFACE 


MC68000 


As 


CLK 


A18 


A17 


A1-A16 


DTACK 


R/W 


LDS 


UDS 


DO-D7 


O8-15[LiI 
v£vguI |l!!! 
III- 
[EL 


—— --—- 
CLK 


VL4500A 
v ° 
’ 
0 
ALE 
RT! 
§ 


new 


E?» 


RAO-RA7 
CAO-CA7 


CAS 
RASO 
RAS1 
MAO-MA7 


RAS 


D 


4164 


EZ- 


4164 I8) 
I8) 


4164 IBI 
— 
-- 
- 
4164 I8I 


8085A CPU INTERFACE TO VL4500A CONTROLLER 


no.1‘5 


ctx 
8085A 
ALE 


READY 
Eb 


W1 


FTEEET m 
*" 


RESET 


‘See section 5.1. p. 12. 


UNUSED '““’UT5 
8000-BFFFH 
C000-FFFFH 


mu 
CA7 
é 


AI8-A15: 
I 
CA1-CA6 
MA7 
N/C 


VL4500A 
am; 
4116 
(TS 
MAO-MAG 
A0 A6 
A0 A6 
new all5_| 
{innit 


CAS 


W 


127$ 


D’ 


—- 


\.%1_:._; 
IZ 


cu< 
ALE 
nov 
iii: 


2icVv 
_RAS1 


||nAs 
in 


nAsb 
0 
o'|||lI 
JJJJJJ 
ADO-A07 
““°"“A6 
CAO 


FSO 
II 


h 


CONFIGURATION 
STRAPS 


I-I 
1-uI_ 
1 


7'1 
in-—_ 
11$ 
__ 
ml 
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VLSI TECHNOLOGY, mc 


FEATURES 
' Inputs are TTL voltage compatible 
' Controls operation of 64K and 
256K dynamic RAMs 
' Creates static RAM appearance 
' One package contains address 
multiplexer, refresh control and 
timing control 
' Directly addresses and drives up to 
2 megabytes of memory without 
external drivers 
' Operates from microprocessor 
clock 
—No crystals, delay lines, or RC 
networks 
—Eliminates arbitration delays 
' Refresh may be internally or 
externally initiated 


PIN DIAGRAMS 


v|.4so2 DIP 


ZEN? II 


EIKE II 
an H 


CAO II 
no B 


MAI I] 


cm II 
an Ll 
an ll 
cu ID 
an III 


GND EB 
an IE] 
cu III 


an: U] 
nu [Ll 
cu TB 
an ID 


was ID 


CA5 Ed 


Ms H] 


nae EH 
cu EB 
no En 


ID Zfii 


ID i 


ID io 
[B ALE 
In E5 


II-J new 


ID nor 
III cur 


IE] R1155 


ID FITS! 


E) CTS? 


11 one 


as am: 


EB vcc 


14 an 


as can 


:2 nu 


El FEFFF6 


E] TWST 
in F50 
E] FS1 


EB an 


[H CA7 


£3 an 


® VLSI TECHNOLOGY, n~1c. 
VL4502 


DYNAMIC RAM CONTROLLER 


' High performance CMOS 
technology 
' Strap-selected wait state 
generation for microprocessor/ 
memory speed matching 
' Ability to synchronize or interleave 
controller with the microprocessor 
system (including multiple 
controllers) 
' 3-state outputs allow multiport 
memory configuration 
' Performance ranges of 
150 ns/200 ns 


0 Compatible with VLSI VL4500A 
and TI TMS4500A, THCT4502 


DESCRIPTION 
The VL4502 is a monolithic DRAM 
system controller providing address 
multiplexing, timing, control and 
refresh/access arbitration functions 
to simplify the interface of dynamic 
RAMs to microprocessor systems. 
The controller contains an 18-bit 
multiplexer that generates the 
address lines for the memory device 
from the 18 system address bits and 
provides the strobe signals required 
by the memory to decode the 
address. A 9-bit refresh counter 
generates up to 512 row addresses 
required to refresh. 


A refresh timer is provided that 
generates the necessary timing to 
refresh the dynamic memories and 
assure data retention. 


uc 
mo 
no 
RW 
HE? 
ALE 
new 
uc 
uc 
mu 
CAO 
CA§o 
R? 
R‘Isa 
cs 
nov 
uc 
ourossaiisosooesoi 


NC 
10 


NC 
11 


CA1 
12 


RA1 
I3 


RA! 
14 


CA2 
15 


HA2 
15 


so 
NC 


so 
NC 


SI 
CLK 


57 
FIT?-'5 


ssFA'§i 


ss~CT§i 


s4 can 


GND 
11 
VL4502 
sa 
REN2 


GND 
IO 


HA3 
II 


CA3 
20 


RAS II 


HA4l22 


CA4 
23 


RA4 
24 


NC 
25 


NC 
26 


SRIYCC 


51 
VCC 


50lHAl 


49,CAl 
nu 
FEB 
hfffd 
uc 
uc 


2 
2 
I 
3 
31 
3 
34 
3 
3 
J 
J 
3 
4 
41 
4 


NC 
HA5 
RAS 
CAI 
GND 
CA7 
FS1 
TWST 
NC 
NC 
CA5 
RA6 
HA5 
HA7 
RA7 
F50 
NC 


ORDER INFORMATION 
Part 
8- 
I 
Access I 
Number 
D 
I 
Time 
Package 
_ 


__7 
7 
7 
_ 
7 "iii! 
VL4502-15PC 
VL4502-15CC 
VL4502-15QC 
15D ns 
Plastic DIP 
Ceramic DIP 
Plastic Leaded Chip Carrier (PLCC) 


VL4502-20PC 
VL4502-20CC 
VL4502-20QC 
200 ns 
Plastic DIP 
Ceramic DIP 
Plastic Leaded Chip Carrier (PLCC) 


Note: 
Operating temperature range: 0°C to +70°C. 
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VL4502 


BLOCK DIAGRAM 


now 
L 
mo-nu_ ADDRESS 
urea 
r 
\ !OLUllN 
L 
cm-cu 
ADDRESS 
_ um-um 
; 
LATCH 


I 
do 
I 
nernesu 
ALE 
? 
counrren I‘ 


__ 
I 
A 
A - 
as 
- 
V 
Fm 
cs _"_"_—" 
SELECT 
P 
or 
REN1 
LATCH 
V 
W 
nan: 
ACR 
_ 
- A 
A 
' 
on 
_ L 
Kc‘w L 
I 
_ 
do 
J 
V 
HTS? 
TIMING 
REFRE5 < 
> ~ 
mo 
V 
FE 
- 
CONTROL 
ARBITER 
° Q 
v 
ET-*5 
— 
- 
V 
as-I 


rwsr 
L 
L 
as 
L 
aemssu I 
F5” 
nma 
|=s1 ~ 
C 
R 
ceuenxron 
nov 


cur as 
I 
~ ~ 
as 
T 
er 
L 
as 
A 
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® VLSI TECHNOLOGY, mc. 


PIN DESCRIPTIONS 


VL4502 


Pln 
Number, 
Note 1 
Pln 
Name 
Description 
g 
g 
g 
g 


RAO—RA8 


27, 32 


4, 7, 10, 
14, 17, 20, 
23,26, 33 


5,6,11, 


CAO—CA8 


MAO—MA8 
13,16,19, 
24, 25, 34 


ALE 
45 


cs 
44 


REN1, REN2 43, 36 


ACR, ACW 
48, 1 


CLK 
41 


REFREQ 
31 


RASO, RAS1 46, 47 
RAS2, RAS3 39,40 
CASIO. CAS1‘ 2, as 


RDY 
42 


TWST 
30 


FSO, FS1 
29, 28 


RESET 
(PLCC 
only) 


3, 8, 9, 15, 
18, 21, 22, 
Row Address-—These address inputs are used to generate the row address for the multiplexer. 


Column Address-—These address inputs are used to generate the column address for the 
multiplexer. 


Memory Address—These three-state outputs are designed to drive the addresses of the 
Dynamic RAM array. 


Address Latch EnabIe—This input is used to latch the 18 address inputs, CS and REN1 and 
REN2. This also initiates an access cycle if chip select is valid. The rising edge (LOW level to 
HIGH level) of ALE returns RAS to the HIGH level. 
Chip Select—A LOW on this input enables an access cycle. The trailing edge of ALE latches the 
chip select input. 
RAS Enable 1 and 2-These inputs areused to select one of four banks of RAM. When REN2 is 
LOW, the lower banks are enabled via CASO, RASO, and RAS1. When REN2 is_HlGH, the higher 
banks are enabled via CAS1, RAS2, and RAS3. REN1 selects RASO, RAS2 or RAS1, RAS3 
when chip select is present. 
Access Control, Read; Access Control, Write—A LOW on either of these inputs causes the (EL 
umn addresses to appear on MA0—MAeir15l the column address stro_I_)__e._:l_'he rising edge of ACR 
or ACVlt_e_rminates the cycle by ending R_ASJand CA3 .strobes. When ACR and ACW are both 
LOW, MAO—MA8, RASO, RAS1, RAS2, RAS3, CASO, and CAS1 go into a HIGH impedance 
(floating) state. 
System Clock—This input provides the master timing to generate refresh cycle timings and 
refresh rate. Refresh rate is determined by the TWST, FS1, FSO inputs. 
Refresh Request—(This input is driven by an open-collector output.) On input, a LOW-going edge 
initiates a refresh cycle and will cause the internal refresh timer to be reset on the next falling 
edge of the CLK. As an output, a LOW-going edge signals an internal refresh request and that 
the refresh timer will be reset on the next LOW-going edge of CLK. REFREQ will remain LOW 
until the refresh cycle is in progress and the current refresh address ispresent on MAO—MA8. 
(Note: REFREQ contains an internal pull-up resistor with a nominal resistance of 10 kilohms.) 
Row Address Strobe—These three-state outputs are used to latch the row address into the bank 
of DRAMs selected by REN1 and REN2. On refresh, all RAS signals are active. 


Column Address Strobe—these three-state outputs are used to latch the column address into 
the DRAM array. 
Ready—This totem-pole output synchronizes memories that are too slow to guarantee 
microprocessor access time requirements. This output is also used to inhibit access cycles 
during refresh when in cycle-steal mode. 
Timing/Wait Strap—A HIGH on this input indicates a wait state should be added to each 
memory cycle. In addition it is used in conjunction with FSO and FS1 to determine refresh 
rate and timing. 
Frequency Select 0; Frequency Select 1—These are strap inputs to select Mode and Frequency 
of operation as shown in Table 1. 
RESET—Active LOW'input to initialize the controller asynchronously. Refresh Address is set to 
1FFH, internal refresh requests, synchronizer, and frequency divider are cleared. This input is 
driven by an open collector driver. 
RESET contains an internal pull-up with a nominal resistance of 100 K0. This allows the pin to be 
left open, if desired. 


Note: 
T 


JQJLH 
""" 
77'" 
__ 
______ 
_ 
____ 
_ 
M 
@ 


1. Pin numbers are for dual in-line package only. 
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TABLE 1: STRAP CONFIGURATION 
VL4502 


___ 
7 
iw 
*7’ 
__ 
7 
7 
I 
___ 
Strap Input Modes, Note 1 
Memory 
Access 
Refresh 
Wait 
Refresh 
l 
Clock 
TWST 
FS1 
FSO 
I 
States 
Rate, Note 2 
Cycles 
L 
I 
*1 
I 
L(3) 
~ 
L 
H 
L 


PP 
IIPP 
I 


0 
External 
0 
External 
CW+61 


‘ 
Clk -1- 91 
OD 


1 


A000) 


IIII 
IIPP 
IPIP 


WT 
I 
T1 
CII(—I-61 
CW+91 


—L—L—L—L 
Clk-:- 106 
*7 
CM%m 
y 


_ 
_ 
"17. 


-hbbm 


TABLE 2: OUTPUT STROBE SELECTION 


Control H H Input 
, 
i 
Selected Output 
REN2 
I 
mam 
C 
mason”; 
RAS1 
, 
RAS2 
RAS3' 
I 
CA‘so 
cAs'1" 
0 
ox 
X 
. 


I 
* 
4 
O 
I 
1711 
I 
TIT 
X 
if 
I 
IX 


7 
7"”! 


-5 
@ 
E 
L 
..X 
. 
. 
E 
X 


._ 
l 
" 
__ 


i 
—L 
.. 
X 
L__._ 
4 
X 
_ 
Notes: 
1. If the strap configuration is changed, the device should be reset in order to insure normal refresh operation. 
2. The maximum refresh rate is a function of the applicable maximum clock frequency (see AC Characteristics). 
3. This strap configuration resets the refresh timer circuitry. 


FUNCTIONAL DESCRIPTION 
VL4502 consists of six basic blocks; 
address and select latches, refresh 
rate generator, refresh counter, the 
multiplexer, the arbiter, and the tim- 
ing and control block. 
ADDRESS AND SELECT 
LATCHES 
The address and select latches allow 
the DRAM controller to be used in 
systems that multiplex address and 
data on the same lines without exter- 
nal latches. The row address latches 
are transparent, meaning that while 
ALE is HIGH, the output at MAO—MA8 
follows the inputs RAO—RA8.- 
REFRESH RATE GENERATOR 
The refresh rate generator is a 
counter that indicates to the arbiter 
that it is time for a refresh cycle. The 
counter divides the clock frequency 
according to the configuration straps 
as shown in Table 1. The counter is 
reset when a refresh cycle is re- 
quested or when TWST, FS1 and FSO 
are LOW. The configuration straps al- 
low the matching of memories to the 
system access time. Upon Power-Up, 
a reset may be accomplished by 


driving all three strap inputs LOW, or 
by driving RESET LOW. During this 
reset period, at least four clock cycles 
should occur. (See RESET, below.) 
REFRESH COUNTER 
The refresh counter contains the ad- 
dress of the row to be refreshed. The 
counter is decremented after each 
refresh cycle. (A LOW-to-HIGH tran- 
sition on TWST sets the refresh 
counter to 1FF15 (511 19). 
MULTIPLEXER 
The multiplexer provides the DRAM 
array with row, column, and refresh 
addresses at the proper times. Its 
inputs are the address latches and 
the refresh counter. The outputs pro- 
vide up to 18 multiplexed addresses 
on nine lines. 
STATIC OPERATION 
- 
The VL4502 is designed for static op- 
eration. As a result, the user can use 
a CLK frequency as low as needed, 
as long as maximum transition times 
are not exceeded. As the CLK rate is 
changed, the refresh rate will change 
accordingly, in keeping with the fre- 
quency-divider specifications above. 
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ARBITER 
The arbiter provides two operational 
cycles; access and refresh. The arbi- 
ter resolves conflicts between cycle 
requests and cycles in execution, and 
schedules the inhibited cycle when 
"used in cycle-steal mode. 
TIMING AND CONTROL 
BLOCK 
The timing and control block executes 
the operational cycle at the request 
of the arbitir._lt provicgithe DRAM 
array with RAS and CAS signals. It 
provides the CPU with a RDY signal. 
It controls the multiplexer during all 
cycles. It resets the refresh rate gen- 
erator and decrements the refresh 
counter during refresh cycles. 
RESET 
The VL4502 is reset by bringing the 
timing straps TWST, FS1, and FSO 
LOW. The refresh address is set to 
1FF, internal refresh requests are 
synchronized, and the frequency 
divider is cleared. This reset can 
occur asynchronously with respect 
to CLK and control signals. In the 
PLCC package, the VL4502 can 
be reset with the RESET signal. In 
either case, at least four clock cycles 
should occur during the reset period. 
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ABSOLUTE MAXIMUM RATINGS 
Ambient Temperature 
Under Bias 
-10°C to + 80°C 
Storage Temperature 
Range 
— 65°C to + 140°C 
Supply Voltage 
Range, VCC, Note 1 -0.5 to +7.0 V 
lnput Voltage Range 
(ally input), Note 1 
-0.5 to +7.0 V 
Continuous Power 
Dissipation 
1.2 W 


Stresses above those listed under 
“Absolute Maximum Ratings" may 
cause permanent damage to the 
device. These are stress ratings 
only. Functional operation of this 
device at these or any other 


DC CHARACTERISTICS: TA = o°c to +1o°c, vcc = 5 v 110% 


VL4502 


conditions above those indicated on 
the operational sections of this 
specification is not implied and 
exposure to absolute maximum 
rating conditions for extended 
periods may affect device reliability. 


"ti 
Symbol 
I 
W 


VIH 
Input HIGH Voltage 
2.4 
Parameter 
I 
I 
5 
M_InTyp(3) 
Max 
Unit 
I Condltlons 


V 


VIL (except REFREQ) 
Input LOW Voltage 


_ 
I 
" 
T 
T" 
"T 
' I 


L.” 
. 
,L.,L_ i., 
_ .,L,_._ 
L 
0.8 
V 
I I 


_ 
I _ 
VIL (REFREQ) 
, Input Low Voltage 
gvss-05 
1.2 
V 


VOH 


.,..):' 
. 
. 
MAO—MA8 RDY 
2.4 
, 


‘ 
OutputHIGH Voltage I RASX, CASX 
I 152.7‘ 
7‘ 
IWREFREOIWIWTIC 
2.4 
' 


V 


I 
___ 


I 


IOH= —1mA 
VCC = 4.5 V 


10H’ = -100 ILA 
VCC = 4.5 V 
L7i_ 
VOL 
I Output LOW Voltage. 
0.4 
V 
IOL = 4mA 
__i_ 
_ 
______ 
_ 
VCC = 4.5 V 


IIH 


I 


I 
REFREQ 
100 


} 
InputHlGHCurrent 
- All Others 
10 
p.A 
IVI = 5.5V 


IIL 


I""7_ 
I 
REFREQ, neser 
Z 
5 
mA 
Input LOW Current 
-I 
5" 9I_IT‘?'§_ __ 
_ 
-10 
1+6 
i 
_ 
_ 
.Vl=0V 


IOZ 


I7 
_.___ 
___ 
__ 
__. 
_ 
'1‘ 
Off-stale 0utpuICu,rr§,n_l 
_ 
_ 
_ 
. 
_ :50 
1+3‘) 
_-._ 
__ 


I vo“=Hoi¢ 4.s,v 
v¢‘¢"= s.sv 


ICC(4) 
Operating Supply Current DC 
20 
mA 
I 
1 TA = 0°C 
v<=<=--~=~ 
Cl 


J1’, 
.. 
Input Capacitance 
5 
_I 
pF 
VI=OV 
I 
f=1MHz 
C0 
OutputCapacitance 
6 
_ 
I 
pF 
lVO=0V 
I=1MHz 


GRAPH 1 


100 


75 


E 


CC 
mA~50 


25 


0012345678 


Notes 


4 
7' 


I 
i 
I 
I 
» I 


I 


I-—_ 
I___ 
I 


' ” 
' 
ITOTAL 
H-I. No 
9 
10 


ICLK(MH1) 


ICC vs CLOCK FREQUENCY 
CL - sso pF CASO, CAS1, MAO—MA8 
vs LOAD 
r 
---._ HE 


I 
1ao pF RASO,-RAS3 


1. Voltage values are with respect to the ground terminal. 
2. The algebraic convention, where the more negative limit is designated as minimum, is used in this data sheet for logic voltage levels only. 
3. All typical values are at VCC = 5 V, TA = 25°C except where otherwise noted. 
4. Refer to Graph 1 for AC Power Consumption Guarantee. In testing, all inputs except CLK are held LOW. 
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AC CHARACTERISTICS: TA = 0°c to +1o°c, vcc = 5 v = 10% _ 
_ 
VL4502 


Symbol 


1 


I 
- 
, 
VL4502-15 
VL4502-=0 
Parameter 
W W i 
at 
Min 
Max__ 
Min 
Max 
Unit 
1-L 
— 
tC(C) I 
CLK Cycle Time 
100 
100 


tW(CH) 


4i 


I 
CLKI-lIGHPuiseIWiIdth 
K 
5 
T 
25 
as 
1% 
tW(CL) 


i 
_ 
— 
- 
7 
r 
cu< LOW Pulse Width 
as 
as 


1 
I 
It 
I 
Transition Time, All Inputs, 


F 
31° 
L 
39. 
IAEL-CL 
I 
Time Delay, ALE LOW to 
10 
CLK Starting LOW, Note 1 
W" 
_ 
_ 
' 
7 
41 
__ 
10 


—Ii— 
ICL-AELII 


-._ 
___ 
Time Delay, CLK LOW to 
Starting LO_W,Note 1 
10 


I 
F 
10 


.7_. 
ICL-AEH 


F 
Time Delay, CLK LOW to 
Starting HIGH, Note 1 
y 
15 
20 


tW(AEH) 
_ 
; 
Pulse Width ALE HIGH 
I 
so 
so 
, 
RS 


IAV-AEL 
cs Valid to ALE LOW 


7 
- 
41 
_ 
Time Delay, Address, REN1’; 
5 
10 


4 


i 


H 
IAEI.-Ax 
Time Delay, ALE LOW to 
Address Not Valid 
_ 
y 
_ 
10 
10 


IAEL-ACL 
@301-slay. ALE LOW to 
MBA) + 30 
I 
I 
MBA) + 
ACX LOW, Notes 3, 4, ,5, 6 
i 
g 


— 
r: 
40‘ 


rAcH-Col. 
Time Delay, ACX HIGH to 
CLKLOW, Notes an, 7 
Q 
2° 
20 


tAcL-cH 
Time Delay, ACX LOW to 
CLK Starting HIGH (to 
remove RDY) 
__, 
40 
40 


IROL-CL 
Time Delay, REFREQ LOW 
toCLK S_t_a_rtIng LOW, Note an 
K 
g 
_ 
A 
35 


*_ 
I 
7 
E 
as 


_ _ 
7 
I 
‘nu 
II 
lW(ROL) 
20 
input Pulse Width, REFREQ LOW 
_ 
in 
, 
20 
I 


Notes: 
1. Coincidence of the trailing edge of CLK and the trailing edge of ALE should be avoided as the refresh/access occurs during the interval from 
ACX HIGH to ALE LOW. 
2. 
and initiate a refresh cycle. 
3. These specifications relate to system timing and do not directly reflect device performance. 
4. On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrence of ALE LOW to ACX LOW. 
If ACX occurs prior to or coincident with ALE then CAS is timed from the CLK HIGH transition that causes RAS LOW. If ACX occurs 20 ns or 
more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW. 
5. For-maximum speed access (internal delays on both access and access grant cycles), ACX should occur prior to or coincident with ALE. 
6. th(RA) is the dynamic memory row address hold time. ACX should follow ALE by tAEL-CEL in systems where the required th(RA) is greater 
than IREL-MAX minimum. 
7. Minimum of 20 ns is specified to ensure arbitration will occur on falling CLK edge. IACH-CL also affects precharge time such that the 
minimum IACH-CL should be equal or greater than: tW(RH) - tW(CL) + 30 ns (for cycle where TOY HIGH occurs prior to ALE HIGH) where 
tW(RH) isthe DRAM RA_S precharge time. 
8. This parameter is necessary only if refresh arbitration is to occur on this LOW-going CLK edge (in systems where refresh is synchronized to 
external events). 
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If ALE rises before ACX and a refresh request is present, the falling edge of CLK after tCL-AEH will output the refresh address to MAO—MA8 
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AC CHARACTERISTICS: TA = o"c to +1o"c, vcc = s v 1 10% 
VL4502 


I I 
I I 
VL4502-15 
IT 
VL4502-I20 
Parameter 
I 
Nlln 
Max 
5* I 
Min 
A 
Max 


IAEL-RE 


_ 
7_ 
_* 
___ 
_ 
_ 
__ 
W” 
____._ 
_____ 
Time Delay, ALE LOW to RAS StartingLOW 
40 
tt(REL) 


' 
**" 
_1 
__1 
_I¢L__ 
_ 
*"’*’7 
u—i—u-— 
“A3 F3"T_"!‘L° 
23° 
IRAV-MA 


Symbol 
A 
L 


Time Delay, Row Address Valid to Memory 
Address Valid 
A 
W A A A W 
50 


_ I 
IAEH-MAV 
Time Delay, ALE HIGH to Valid 
' 
Memory Address? 
L 
70 


IAEL-RYL 
Time Delay, ALE to RDY Starting LOW 
(TWST = 
1 or Refresh in Progress) 
25 
‘ 
25 


IAEL-CEL 
Time Delay, ALE LOW to CAS Starting LOW 
F 
60 If 
A 
iso 
10 
I 
I 
200 


IAEH-HEH 


______ 
T 
JT777’ 


tt(MAV) 
Address Transition Time 
T” 
I 
15 
I 
Time Delay, ALE HIGH to_RAS Starting HIGH 
I 
W If If 
I 
I as 
If 
1 has 


20 


— 
7 
W7 
I 
____ 
—¢i—- 
tACL-MAX 
L 
IMAV-CE 
Time Delay, Memory Address Valid to CAS 
0 
Starting 
W 
i 


Row Address Hold from ACX LOW 
15‘ 
I 
I 
“ 
L 
I 
1 
20 
' 
I 


CAS Fail Time 
15 
I 
W29 
tt(CEL) 
A 
A 
L 
tAACL-CE 


__ 
__1 
_ 
1 
I1 
_ 
I 
7 
7 
Time Delay, ACX LOW to CAS Starting LOW 
50 SW ' 
I "Baa 
If 
, 
I 
I 
130 
Time Oelay, ACX to RASStarting HIGH W 
1 
A 
59 
tt(REH) 
RAS Rise Time 
15 
20 


IACH-CE 


tACH-REAH 


H 
Time Delay, ACX HIGHA_toCASAAStarting 
A 
5 
35 
10 ff 
A 
{*9 
"<<=EH> 
% Rise um}; 
I 
5' 
35 


IACH-MAX 
Column Address Hold from ACX HIGH 
5 
15 


I 
so 
I 
L 
_ 
T 
7? 
L_2o 


I 
_ 
__ 
IOH-RYH 


__ 
_ 
1 
1-q""*" 
7' 
Time Delay, CLK HIGH to RDY Starting 
HIGH (After ACX LOW), Note 9 
45 


tRF.L-RFL 


l___ 
IIl__L_"" 
7'" 
77' 
Time Delay, REFREQ External Until 
Supported by REFREQ Internal 
I 
25 
30 


ICH-RFL 
TimeDelay, c[T< HIGH umn REFREQ 
Internal Starting LOW 
30 


I 
35 


ICL-MAV 
Time Delay, CLK LOW Until Refresh 
Addgressggl/alid 
100 


IOH-RRL 
W5_As Startin LOW 
A 
Tinié Delay, CLK HIGH umn Refresh 
10 
50 
15 
60 


tMAV-RRL 
‘ 
Until Refresh RAS LOW 
Time De ay Refresh Address Valid I 
I 
I 
J0 


,, 
Ir 
A 
L 
A 
A 
F 


I 
A 
0 


ICL-FIFH 


_'I-Q 
Ii’ 
in-1 
f____;___ 
l__ I-I 
J 
r'_ _* 
i" 
Time De ay CLK LOW to REFREQ Starting 
HIGH (3 Cycle Refresh) 
50 
I 
55 


tCH-RFIHF 
Time De ay CLK HIGH to REFREQ Starting 
HIGH (4 Cycle Refresh) 


_- 
_ 


55 


tCSH-RRH 
Time De ay CLK HIGH to Refresh RAS 
Starting HIGH 
5 
40 
10 
, 
45 


ICH-MAX 
&a 


Note: 
9. RDY returns HIGH on the rising edge of CLK. If TWST = 0, then on an access grant cycle RDY goes HIGH on the same edge that causes 
access RAS LOW. If TWST = 1, then RDY goes to the HIGH level on the first rising CLK edge after ACX goes LOW on access cycles and on 
the next rising edge after the edge that causes access RAS LOW on access grant cycles (assuming ACX LOW). 


~ 


I 


- 


I 


' 
___ 
_i 
___r_ 
_'______ 
I 
is 
~ 


I 


_J 
'*_;'*1 
_ 
1 


I 


___l"I 
_'___ 
" 
1 


I 
Time De ay Refresh Address Hold 
After CL HIGH 
15 


' 
20 
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AC CHARACTERISTICS: TA = o"c to +70"c, vcc = 5 v + 10% 
1 


L 
—' 
_L 
—' 
_L_** 
_ 
" 
L 
’** 
L_ 
Y; 
A 
A 
A 


Symbol 


A 
A 
VL4502-15 
A 
IA 
VL4502-20 
AA AA 
A 


_ 
r 
_ 
L 


*|I 
~ 
_ 
in 
L 
Parameter 
I I 
Min 
I 
Max 
Min 
I 
”lTlax 
I 
Unit 
__ 
__ 
A 
_ 
1: 
AA 
_ 
Ai 
I 
L 
ICHI-REL 
A 
Time Delay, CLK HIGH Until Access RAS 
Starting LOW 
A 
so 
' 
I 
70 


tCL-CEL” 


LLL 
h 
A 
Time Delay, CLK LOW to Access CAS 
Starting LOW, Note 10 
' 
I 
T I 


LL 
7' 
_~" 
7"?‘ 
L 
_ 
’ 


I 


fi 
— 
— 
J 
125 
140 


ICL-MAX 
RowAddress Hold After CLK 
‘ 
25 
L 
30 
I 
tW(ACL) 


_ 
I Ex LOW Width 
I 
I 
I 


\ 
95L 


A 
120 I 
I 
IREALA-MA 


LLfe~ 
- 
L 
L_ 
X 
Row Address Hold From RAS LOWAAA 
I 
25 
AA 
30 
1 
J 
tt(RYL) 


y 
_ 
_ 


A 
A 
RDAYFallTirAne 
AAA 
A 
10 
A 
A 
AA 
A15 
L 
ns 
tt(RYH) 
RDY Rise Time 
I I 
I 
Ti” 
S 
Io" 


I 


— 1 
25 I 


L 
L 
, 
L 


A 
20 
~ 
A 
A 
.L 
tdis_A 


I 
__ 
L 
L_L_ 
Output Disable time (3-State Outputs) 


_ L 
I 


I 
100 
125 


IAEH-MAX 
Column Address Hold from ALE HIGH 
A i 
we 
~ 
A 
I 
15“ 


ten 
Output Enable Time (3-State Outputs) 
65 
80 


ICAV-CEL 
Column Address Setup to CAS After 
Refresh 


L 
0 
L 
LL 
0 
‘I, 
LL 
A 


ICH-CEL 


_ 
'*i 
LLL 
_ 


A 
Time Delay, CLK HIGH to Access 


I 
ACAS Starting LOW, Note 9 
140 
180 


I RESET AA 
Power Up RESAET 
A 
FourA(4) Clock CycIesAA 
A 


Notes: 
10. On the access grant cycle following refresh, the occurrence of CAS LOW depends on the relative occurrrence of ALE LOW to ACX LOW. If 
ACX occurs prior to or coincident with ALE then CAS is timed from the CLK LOW transition that causes RAS LOW. If ACX occurs 20 ns or 
more after ALE then CAS is timed from the CLK LOW transition following the CLK HIGH transition causing RAS LOW. 


OUTPUT LOAD CONDITIONS: vcc = 5.0 v 
AC TESTING INPUT, OUTPUT WAVEFORM 


vcc 


I 
1020 


RDY 
RA$0'RAS3' 
*- 


€ 
CASO. CAS1 


MAO—MA8 



880 
E5Io '0TI 
~iKIo 


VCC 


1020 


REFREQ 


89° 
% 350 pF 
1020 


vcc 


900 


720 
I 35° pp 


VCC 


900 


:[40pF 


VCC 


930 


I40pF 
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3.0 V 
2.4V 
V 
‘ 
0.8V 
OV 
INPUT 
OUTPUT 


AC TESTING INPUTS ARE DRIVEN AT 3.0 V FOR A LOGIC "1" AND 0.0 V 
FOR A LOGIC "0". TIMING MEASUREMENTS ARE MADE AT 2.4 V FOR A 
LOGIC "1" AND 0.8 V FOR A LOGIC "O" AT THE OUTPUTS. 
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TIMING DIAGRAMS 
ACCESS CYCLE TIMING 


-<?——-— leis: 
‘— Mom 
\\\ 
I 
lu:L..cL 
I-v-— 
lu(cL| 
‘CL "H 
|<— lu(Atm—>| —>I 
Ir 
--> 
—lr 
II 
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I 
ALE 
2 
I 


—’-> 
lust. CL 
A 
A 
hv-An -1<—>. 
<—'- 
lA:L-Ax 
22:’. 
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I< 
~ lwucu ' 
TI‘ 
’ 
4i-—— hit-Act 
>I< 
lAcL-ca 'i> 
"—" ‘ACR-CL 
A 


%—————- IAEPrJA:a 
IACL-MAI --A4-—> 
I‘ 
'"".mI‘:::— Inca-an 
"W 16161616161616161'61€>"6161*i61616161616161616161 


"INA 
<— 
I-<———- Ina aux ‘i-* M" ca 
—--> 
4--— lticcu 
<- hen cm 
mew) 


I 
I 
. 
' 
] 
1' 
A 
h 
v) 
- 
. 
A 
- 
. 


<':Ts‘> 
| 
‘J 
-;<~i- lAcL-cui-*7 
IAEL-ML 
-- 3*-- 
l'f——> 
lcn-um 


RDY 
I 


-—> <i gun“, 
i> 
‘tram; 


< 
or 
o 
lA:Lc£L 
" 
L 
* 
i””>I 


REFRESH REQUEST TIMING 


‘K 


cu: 


I 
I 
InoL-cL 
I 
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TIMING DIAGRAMS (Cont.) 
OUTPUT a-sure TIMING 
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TIMING DIAGRAMS (Conn) 
TYPICAL ACCESS/REFRESH/ACCESS cvcua (a-cvcuz, wvsr = 0) 
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TIMING DIAGRAMS (Cont.) 
TYPICAL ACCESS/REFRESH/ACCESS cvcua (a-cvcuz, wvsr = 1) 
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READY (RDY) SIGNAL TIMING (WAIT STATE OPERATION, TWST = 1) 
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N 


FEATURES 
- 
SCSI INTERFACE 


~ Interface to 1.5M bps (asynchronous) 


- Supports initiator and target roles 


- Parity generation with optional check- 
ing 


- Arbitration support 


- Direct control of all bus signals 


- High current outputs drive SCSI bus 


MPU INTERFACE 
- Memory or I/O mapped interface 


- DMA of programmed I/O 


- Normal or block mode DMA 


- Optional MPU interrupts 


PIN DIAGRAM 


VL53C8O 
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D1 
—DB7 I 
39 1 
D2 
-DB6 I 
38 I 
D3 
-DB5 I 
4 
37 I 
D4 
-DB4 I 
5 
36 I 
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VLSI TECHNOLOGY, INC. 
VL53C8O 
SMALLCOMPUTER SYSTEM INTERFACE (SCSI) 


DESCRIPTION 
The VLSI Technology VL53C8O SCSI 
device is a 40-pin CMOS device 
designed to accommodate the Small 
Computer Systems Interface (SCSI) 
as defined by the ANSI X3T9.2 
committee. The VL53C8O operates as 
both the initiator and the target and 
can therefore be used in host adapter, 
host port, and formatter designs. This 
device supports arbitration, including 
reselection. Special high-current open- 
collector output drivers, capable of 
sinking 48 mA at 0.5 V, connect 
directly to the SCSI bus. 


The VL53C8O interfaces with the sys- 
tem microprocessor as a peripheral. 


BLOCK DIAGRAM 


CPU INTERFACE 
READY 
DRO 
_‘oR 
A0 


The device is controlled by reading and 
writing several internal registers which 
are addressed as standard or memory 
mapped I/O. 
DMA transfers require little 
CPU support because the VL53C8O 
controls the necessary handshake 
signals. The VL53C8O interrupts the 
MPU when it detects a bus condition 
requiring service. Normal and block 
mode DMA is also available to match 
several popular DMA controllers. 


The VL53C8O is available in a 40-pin 
plastic or ceramic DIP as well as a 44- 
pin plastic leaded chip carrier. 
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DATA 
SCSI DATA 
OUTPUT 
REG 
REG 
STAT REG 
REG 
REG 
REG 
REG 
REG 
In 
.|f: 
1I 


. 
l 


F 



ORDER INFORMATION 


Part 
Number 
Package 


VL53C80-PC 
Plastic DIP 
VL53C80-CC 
Ceramic DIP 


-AEN 
-RST 
-C/O 
-REQ 
—D BP 
DBO-D B7 
-ACK 
-I/O 
-MSG 
SCSI BUSINTERFACE 


VL53C80-QC 
Plastic Leaded Chip Carrier (PLCC) 


Note:Operating temperature range is 0°C to +70°C. 
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SIGNAL DESCRIPTIONS 


Pln 
Slgnal 
Number 
Type 
Slgnal 
Name 


D0-D7 


A0-A2 


—RESET 


—EOP 


-IOR 


--IOW 


-cs 


-DACK 


mo 


one 


READY 


VDD 


GND 


‘All pins interface directely with the microprocessor. 
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1, 40-34 


30, 32, 33 
I‘ 


28 


27 


24 


29 


21 


26 


23 


22 


25 


31 


11 


VL53C8O 


Slgnal 
Descrlptlon 


Three-state microprocessor data bus lines. Active high when an output. 


These signals are used with -CS, -IOR, or -IOW to address the internal 
registers. 


Reset - Clears all registers. It does not force the SCSI signal -RST to the 
active state. -RESET is active low. 


End Of Process - Used to terminate a DMA transfer. If asserted during a 
DMA cycle, the current byte will be transferred but no additional bytes will 
be requested. 


l/O Read - Used to read an internal register selected by -CS and A0-A2. It 
also selects the Input Data Register when used with -DACK. -IOR is 
active low. 


I/O Write - Used to write an internal register selected by CS and A0-A2. 
When used with -DACK it selects the Output Data Register . -IOW is 
active low. 


Chip Select - An active low signal that enables a read or write of the 
internal register selected by address lines A0-A2. 


DMA Acknowledge - This active low signal resets DRQ and selects the 
data register for input or output of datatransfers. 


Interrupt Request - Informs the microprocessor of an error condition or an 
event completion. 
' 


DMA Request - Indicates that the data register is ready to be read or 
written. DRO occurs only if DMA mode is true in the Command Register. 
lt is cleared by -DACK. 


Ready - Can be used to control the speed of block mode DMA transfers. It 
goes active to indicate the chip is ready to send/receive data and remains 
false after a transfer until the last byte is sent or until the DMA Mode bit is 
reset. 


+5 V. 


Ground. 
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SIGNAL DESCRIPTIONS 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


-ACK 
14 
I/O‘ 
Acknowledge - Driven by an initiator, -ACK shows an acknowledgment for 
a REQ/ACK data transfer handshake. In the target role, -ACK is received 
as a response to the —REQ signal. 


-ATN 
15 
I/O’ 
Attention - Driven by an initiator, -ATN indicates an attention condition. 
This signal is received in the target role. 


-BSY 
13 
I/O‘ 
Busy - Indicates that the SCSI bus is being used and can be driven by both 
the initiator and the target device. 


-C/D 
18 
I/O’ 
Control or Data - Driven by the target, -C/D indicates Control or Data 
information is on the data bus. It is received by the initiator. 


-DBO- -DB7, 
9-2, 10 
I/O’ 
Data Bus - These eight data bits (—DBO- -DB7), plus a parity bit (—DBP) 
-DBP 
form the data bus. -DB7 is the most significant bit and has the highest 
priority during the Arbitration phase. Data parity is odd. Parity is always 
generated and optionally checked. Parity is not valid during arbitration. 


-I/O 
17 
I/O‘ 
Input/Output - Driven by a target which controls the direction of data 
movement on the SCSI bus. True (low) indicates input to the initiator. 
It is 
also used to distinguish between Selection and Reselection phases. 


-MSG 
19 
I/O‘ 
Message - Received by the initiator, and driven by the target during the 
Message phase. 


—REQ 
20 
I/O‘ 
Request - Driven by a target, —REQ indicates a request for a REQ/ACK 
data transfer handshake. It is received by the initiator. 


-RST 
16 
I/O‘ 
Reset - Indicates an SCSI bus reset condition. 


-SEL 
12 
I/O‘ 
Select - Used by an initiator to select a target or by a target to reselect an 
initiator. 


‘Bidirectional, active low, open collector signals with 48 mA sink capability. All pins interface directly with the SCSI bus. 
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FUNCTIONAL DESCRIPTION 
TABLE 1. REGISTER SUMMARY 
The VL53C8O Small Computer Systems 
Address 


A2 
u 
R/W 
Register Name 


0 
Current SCSI Data 


O 
Output Data 


o n 
Initiator Command 


0 
Target Command 


1 
Current scsi Bus Status 


1 
Select Enable 


1 
Bus and Status 


1 Z 
Start DMA Send 


1 
u 
Start DMA Target Receive 


1 
E 
Reset Parity/Interrupts 


1 
I 
Start DMA Initiator Receive 


Interface (SCSI) device is seen as a set 
eight registers to the controlling MPU. 
By reading and writing the correct 
registers, the MPU may start any SCSI 
Bus function or may sample and assert 
any signal on the SCSI Bus. This 
permits the user to use all or portions of 
the SCSI protocol in software. These 
registers are read (written) by activating 
-CS with an address on A0-A2, and 
then issuing an -IOR (-IOW) pulse. 
The following section will describe the 
operation of the internal registers. 


SCSI signal names are used to define 
the contents of the internal registers. 
Even though the bus is active low, a 
one (1) is used to indicate signal 
assertion and a zero (0) is used to 
indicate the inactive state. Se'e Table 1. 


DATA REGISTERS 
The data registers are used for the 
transfer of SCSI commands, data, 
status, and message bytes between the 
microprocessor Data Bus and the SCSI 
Bus. The VL53C8O does not handle 
any information that passes through the 
data registers. The data registers 
consist of the transparent Current SCSI 
Data Register, the Output Data Regis- 
ter, and the Input Data Register. 


Current SCSI Data Register 
Address 0 (Read Only) - The Current 
SCSI Data Register is a read only 
register which permits the microproces- 
sor to read the active SCSI Data Bus. 
This is done by activating -CS with an 
address on A2-A0 of 000, and issuing 
an -IOR pulse. If parity checking is 
enabled, the SCSI Bus parity is 
checked at the beginning of the read 
cycle. This register is active during a 
programmed I/O data read, or during 
Arbitration to inspect for higher priority 
arbitrating devices. Parity is not 
assured valid during Arbitration. 


normal MPU write, or under DMA 
control, by using -IOW and -DACK. 
This register is further used to assert 
the correct ID bits on the SCSI Bus 
during the Arbitration and Selection 
phases. 


7 
6 
5 
4 
3 
2 
‘I 
0 


—DB7 —DB6 —DB5 -DB4 -DB3 -DB2 -DB1 -DBO 


Input Data Register 
Address 6 (Read Only) - The Input Data 
Register is a read only register that is 
used to read latched data from the 
SCSI Bus. Data is latched either during 
a DMA Target receive operation as 
-ACK goes active, or during a DMA 
Initiator receive when -REO goes 
active. 
The DMA Mode bit (port 2, bit 
1) is to be set before data can be 
latched in the Input Data Register. This 
7 
6 
5 
4 
s 
2 
1 
0 
register may be read under DMA control 
_DB7 _DB6 _DB5 _DB4 _DB3 _DB2 _DB1 _DBO 
using -IOR and -DACK. Parity may be 


Output Data Register 
Address O (Write Only) - The Output 
_ 
_ 
_ 
_ 
7 
s 
5 
4 
s 
2 
1 
o 
Data Register IS a write only register 
h 
' 
d 
t at IS use 
to send data to the SCSI 
Bus. This done by either using a 


checked when the Input Data Register 
is loaded, if desired. 


—DB7 —DB6 -DB5 —DB4 -DB3 -DB2 -DB1 —DBO\ 
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Inltiator Command Register 
Address 1 (Read/Write) - The Initiator 
Command Register is a read/write 
register that is used to assert some 
SCSI Bus signals, to monitor those 
signals, and to monitor the progress of 
bus arbitration. Many of these bits are 
significant only when being used as an 
Initiator. However, most can be used 
during Target role operation. Values for 
the Read and Write registers are shown 
below, respectively. 


7 
6 
5 
4 
3 
2 
1 
0 


ASRT 
AIP 
LA 
ASRT ASRT ASRT ASRT ASRT 
-RST 
-ACK -BSY -SEL -ATN 


7 
6 
5 
4 
3 
2 
1 
0 


ASRT TEST DIFF ASRT ASRT ASRT ASRT ASRT 
-RST MODE ENBL -ACK -BSY —SEL -ATN DBAJTSA 


The following is a description of the 
operation of all bits in the Initiator 
Command Register. 


Bit 7 - Assert -RST - Whenever a one 
(1) is written to bit 7 of the Initiator 
Command Register, the -RST signal is 
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asserted on the SCSI Bus. The -RST 
signal stays asserted until this bit is 
reset or an external -RESET occurs. 
After this bit is set (1 ), IRQ goes active. 
Then, all internal logic and control 
registers are reset (except for the 
interrupt latch and the Assert -RST bit). 
Writing a zero (0) to bit 7 of the Initiator 
Command Register releases the -RST 
signal. Reading this register shows the 
status of this bit. 


Bit 6 - AIP (Arbitration in Progress) 
(Read Bit) - This bit is used to deter- 
mine if arbitration is in progress. For 
this bit to be active, the Arbitrate bit 
(port 2, bit 0) must have been previ- 
ously set . It indicates that a "bus free" 
condition has been detected, that the 
chip has asserted -BSY, and the 
contents of the Output Data Register 
(port 0) onto the SCSI Bus. AIP will 
remain active until the Arbitrate bit is 
reset. 


Bit 6 - Test Mode (Write Bit) - This bit 
may be written during a test environ- 
ment to disable all output drivers, 
thereby removing the VL53C8O from 
the circuit. Resetting this bit returns the 
device to normal operation. 


Bit 5 - LA (Lost Arbitration) (Read Bit) - 
This bit, when active, indicates that the 
VL53C8O has found a bus free condi- 
tion, arbitrated for use of the bus by as- 
serting -BSY and its ID on the Data 
Bus, and lost Arbitration due to -SEL 
being asserted by another bus device. 
For this bit to be active, the Arbitrate bit 
(port 2, bit 0) must be active. 


Bit 5 - DIFF ENBL (Differential Enable) 
(Write Bit) - This bit must be written with 
a zero (0) for proper operation. 


Bit 4 - Assert -ACK - This bit is used by 
the bus initiator to assert -ACK on the 
SCSI Bus. To assert -ACK, the Target 
Mode bit (port 2, bit 6) must be false. 
Writing a zero (0) to this bit resets 
-ACK on the SCSI Bus. Reading this 
register simply reflects the status of this 
bit. 


Bit 3 - Assert -BSY - Writing a one (1) 
into this bit position asserts -BSY onto 
the SCSI Bus. Conversely, a zero (0) 
resets the -BSY signal. Asserting 
-BSY indicates a successful selection 
or reselection and resetting this bit 
creates a bus disconnect condition. 


Reading this register simply reflects the 
status of this bit. 


Bit 2 - Assert -SEL - Writing a one (1) 
into this bit position asserts -SEL onto 
the SCSI Bus. -SEL is normally 
asserted after Arbitration has been 
correctly completed. -SEL may be 
released by resetting this bit to a zero 
(0). A read of this register shows the 
status of this bit. 


Bit 1 - Assert -ATN - -ATN may be 
asserted on the SCSI Bus by setting 
this bit to a one (1) if the Target Mode 
bit (port 2, bit 6) is false. -ATN is 
normally asserted, by the initiator, to 
request a Message Out bus phase. 
Note that since Assert -SEL and Assert 
-ATN are in the same register, a select 
with -ATN may be implemented with 
one MPU write. -ATN may not be 
asserted by resetting this bit to zero (0). 
A read of this register simply reflects the 
status of this bit. 


Bit 0 - Assert Data Bus - The Assert 
Data Bus bit, when set, allows the 
contents of the Output Data Register to 
be enabled as chip outputs on the 
signals -DBO through —DB7. Parity is 
generated and asserted on -DBP also. 


Connected as an Initiator, the outputs 
are only enabled if the Target Mode bit 
(port 2, bit 6) is false, the received 
signal —l/O is false, and the phase 
signals (-C/D, -I/O, and -MSG) match 
the contents of the Assert -C/D, Assert 
-V0, and Assert -MSG in the Target 
Command Register. 


This bit should also be set during DMA 
send operations. 


Mode Reglster Address 2 (Read/ 
Wrlte) 
The Mode Register is used to control 
the operation of the chip. This register 
decides whether the VL53C8O operates 
as an Initiator or a Target, whether DMA 
transfers are being used, whether parity 
is checked, and whether interrupts are 
generated on various external condi- 
tions. This register may be read to 
inspect the value of these internal 
control bits. The operation of these 
control bits are shown below. 
' 


7 
6 
5 
4 
3 
2 
1 
O 


BLK 
TAR- 
EN 
EN 
EN 
MONI- DMA 
ARB 
MODE GET 
PAR 
PAR 
EOP 
TOR MODE 
DMA MODECHKG 
INT 
INT 
BSY 
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Bit 7 - Block Mode DMA - The Block 
Mode DMA bit controls the characteris- 
tics of the DMA DRO/-DACK hand- 
shake. When this bit is reset (0), and 
the DMA Mode bit is active (1 ), the 
DMA handshake uses the normal 
interlocked handshake. The rising edge 
of -DACK shows the end of each byte 
being transferred. In block mode 
operations, Block Mode DMA bit set (1 ) 
and DMA Mode bit set (1 ), the end of 
-IOR or -IOW signifies the end of each 
byte transferred and -DACK is allowed 
to remain active throughout the DMA 
operation. READY can then be used to 
request the next transfer. 


Bit 6 - Target Mode - The Target Mode 
bit allows the VL53C8O to operate as 
either an SCSI Bus Initiator, bit reset 
(0), or as an SCSI bus Target device, 
bit set (1 ). In order for the signals -ATN 
and -ACKto be asserted on the SCSI 
Bus, the Target Mode bit must be reset 
(0). In order for the signals -DC, -I/O, 
-MSG, and —REQ to be asserted on the 
SCSI Bus, the Target Mode bit should 
be set (1 ). 


Bit 5 - Enable Parity Checking - The 
Enable Parity Checking bit decides 
whether parity errors will be ignored or 
saved in the parity error latch. 
If this bit 
is reset (0), parity will be ignored; if this 
bit is set (1), parity errors will be saved. 


Bit 4 - Enable Parity Interrupt - The 
Enable Parity Interrupt bit, when set (1), 
will cause an interrupt (IRO) to occur if 
a parity error is detected. A parity 
interrupt will only be generated if the 
Enable Parity Checking bit (bit 5) is also 
enabled (1). 


Bit 3 - Enable EOP Interrupt - The 
Enable EOP Interrupt, when set (1), 
causes an interrupt to occur when an 
-EOP (End of Process) signal is 
received from the DMA controller logic. 


Bit 2 - Monitor Busy - The Monitor Busy 
bit, when true (1) causes an interrupt to 
be generated for an unplanned loss of 
--BSY. When the interrupt is generated 
due to loss of -BSY, the lower six bits 
of the Initiator Command Register are 
reset (0) and all signals are removed 
from the SCSI Bus. 


Bit 1 - DMA Mode - The DMA Mode bit 
is normally used to enable a DMA 
transfer and must be set (1) prior to 
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writing ports 5 through 7. Ports 5 
TABLE 2. SCSI INFORMATION TRANSFER PHASES 
through 7 are used to initiate DMA 
transfers. The Target Mode bit (port 2, 
bit 6) must be consistent with writes to 
port 6 and 7 (i.e., set (1) for a write to 
port 6 and reset (0) for a write to port 7). 
The control bit Assert Data Bus (port 1, 
bit 0) must be true (1) for all DMA send 
operations. In the DMA mode, —REQ 
and -ACK are controlled automatically. 


The DMA Mode bit is not reset when 
the receipt of an -EOP signal occurs. 
Any DMA transfer may be stopped by 
writing a zero (0) into this bit. Care must 
be taken not to cause -CS and -DACK 
to become active simultaneously. 
-BSY must be active to set the DMA 
Mode bit. 


Bit 0 - Arbitrate - The Arbitrate bit is set 
(1) to start the Arbitration process. Prior 
to setting this bit, the Output Data 
Register should contain the proper 
SCSI device ID value. Only one data 
bit should be active for SCSI Bus 
arbitration. The VL53C8O will wait for a 
bus free condition before entering the 
arbitration phase. The results of the 
arbitration phase are determined by 
reading the status bits LA and AIP (port 
1, bits 5 and 6, respectively). 


Target Command Register 
Address 3 (Read/Write) - When 
connected as a target device, the 
Target Command Register allows the 
MPU to control the SCSI Bus Informa- 
tion Transfer phase and also to assert 
—REQ simply by writing this register. 
The Target Mode bit (port 2, bit 6) must 
be true (1) for bus assertion to oixur. 
The SCSI Bus phases are described in 
Table 2. 
- 


When connected as an Initiator with 
DMA Mode true and if the phase lines 
(-I/O, -C/D, and -MSG) do not match 
the phase bits in the Target Command 
Register, a phase mismatch interrupt is 
caused when -REO goes active. In 
order to send data as an Initiator, the 
Assert -I/O, Assert -C/D, and Assert 
-MSG bits must match the correspond- 
ing bits in the Current SCSI Bus Status 
Register (port 4). The Assert —REQ bit 
(bit 3) has no meaning when operating 
as an Initiator. 


7 
6 
5 
4 
3 
2 
1 
0 
7 
6 
5 
4 
3 
2 
1 
0 


X 
X 
X 
X 
ASRT ASRT ASRT ASRT 
—REQ -MSG -C/D 
—l/O 


Assert 
Assert 
- 
-C D 
Bus Phase 


Data Out 


Unspecified 


Command 


Message Out 


Data In 


Unspecified 


Status 


Message In 


=O 
Assert 
-MSG 


0 


1 


0 


1 


0 


1 


0 


1 


The VL53C8O uses bit 7 of this register 
to determine when the last byte of DMA 
transfer is sent to the SCSI Bus. This 
flag is needed since the End of DMA bit 
in the Bus and Status Register only 
display when the last byte was received 
from the DMA. 


Current SCSI Bus Status Register 
Address 4 (Read Only) - The Current 
SCSI Bus Status Register is a read only_ 
register which is used to monitor seven 
SCSI Bus control signals plus the Data 
Bus parity bit. An Initiator device can 
use this register to determine the 
current bus phase and poll —REQ for 
pending data transfers. This register 
may also be used to determine why a 
certain interrupt occurred. Values for 
the Current SCSI Bus Status Register 
are shown below. 


7 
6 
5 
' 
4 
3 
2 
1 
0 


-RST -BSY —REQ -MSG -C/D 
-I/O -SEL -DBP 


Select Enable Register 
Address 4 (Write Only) - The Select 
Enable Register is a write only register 
which is used as a mask to monitor a 
signal ID during a selection attempt. 
The simultaneous occurrence of the 
correct ID bit, -BSY false, and -SEL 
true will cause an interrupt. This 
interrupt can be disabled by resetting all 
bits in this register. If the Enable Parity 
Checking bit (port 2, bit 5) is active (1 ), 
parity will be examined during selection. 


—DB7 -DB6 -DB5 -DB4 -DB3 -DB2 -DB1 —DBO 
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Bus and Status Register 
Address 5 (Read Only) - The Bus and 
Status Register is a read only register 
which may be used to monitor the re- 
maining SCSI control signals not found 
in the Current SCSI Bus Status Register 
(-ATN and -ACK), and six other status 
bits. Below is a description of each bit 
of the Bus and Status Register. 


7 
6 
5 
4 
3 
2 
1 
0 


END 
DMA 
PAR 
INT 
O 
BSY -ATN -ACK 
OF 
RQST ERR RQST MCH 
ERR 
DMA 
ACT 


Bit 7 - End of DMA Transfer - The End 
of DMA Transfer bit is set if —EOP, 
-DACK, and either -IOR or -IOW are 
both active for at least 100 ns. Since 
the -EOP signal can occur during the 
last byte sent to the Output Data 
Register (port 0), the -REO and -ACK 
signals must be monitored to insure that 
the last byte has been transferred. This 
bit is reset when the DMA Mode bit is 
reset (0) in the Mode Register (port 2). 


Bit 6 - DMA Request - The DMA 
Request bit permits the MPU to sample 
the output pin DRO. DRO can be 
cleared by asserting -DACK or by 
resetting the DMA Mode bit (bit 1) in the 
Mode Register (port 2). The DRO 
signal does not reset when a phase 
mismatch interrupt occurs. 


Bit 5 - Parity Error - This bit is set if a 
parity error occurs during a data receive 
or a device selection. The Parity Error 
bit can only be set (1) if the Enable 
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Parity Check bit (port 2, bit 5) is active 
(1). This bit may be cleared by reading 
the Reset Parity/Interrupt Register (port 
7). 


Bit 4 - Interrupt Request Active - This bit 
is set if an enabled interrupt condition 
occurs. 
It reflects the current state of 
the IRQ output and can be cleared by 
reading the Reset Parity/Interrupt 
Register (port 7). 


Bit 3 - Phase Match - The SCSI signals, 
-MSG, -C/D, and —l/O, represent the 
current information transfer phase. The 
Phase Match bit indicates whether the 
current SCSI Bus phase matches the 
lower three bits of the Target Command 
Register. Phase Match is continuously 
updated and is only significant when 
operating as a bus initiator. A phase 
match is required for data transfers to 
occur on the SCSI Bus. 


Bit 2 - Busy Error - The Busy Error bit is 
active if an unexpected loss of the 
-BSY signal has occurred. This latch is 
set whenever the Monitor Busy bit (port 
2, bit 2) is true and —BSY is false. An 
unexpected loss of —BSY will disable 
any SCSI outputs and will reset the 
DMA Mode bit (port 2, bit 1). 


Bit 1 - ATN - This bit reflects the 
condition of the SCSI Bus control signal 
-ATN. This signal is normally moni- 
tored by the Target device. 


Bit 0 - ACK - This bit reflects the 
condition of the SCSI Bus control signal 
-ACK. This signal is normally moni- 
tored by the Target device. 


DMA REGISTERS 
Three write only registers are used to 
initiate all DMA activity. They are Start 
DMA Send (port 5), Start DMA Target 
Receive (port 6) and Start DMA Initiator 
Receive (port 7). Simply writing these 
registers starts the DMA transfers. 
Data presented to the VL53C8O on 
signals DO through D7 during the 
register write is meaningless and has 
no effect on the operation. Prior to 
writing these registers, the Block Mode 
DMA bit (bit 7), the DMA Mode bit (bit 1) 
and the Target Mode Bit (bit 6) in the 
Mode Register (port 2) must be 
appropriately set. The individual 
registers are briefly described as 
follows. 


Start DMA Send 
Address 5 (Write Only) - This register is 
written to initiate a DMA send, from the 
DMA to the SCSI Bus, for either initiator 
or target role operations. The DMA 
Mode bit (port 2, bit 1) must be set prior 
to writing this register. 


Start DMA Target Receive 
Address 6 (Write Only) - This register is 
written to initiate a DMA receive, from 
the SCSI Bus to the DMA, for Target 
operation only. The DMA Mode bit (bit 
1) and the Target Mode bit (bit 6) in the 
Mode Register (port 2) must both be set 
(1) prior to writing this register. 


Start DMA Initiator Receive 
Address 7 (Write Only) - This register is 
written to initiate a DMA receive, from 
the SCSI Bus to the DMA, for initiator 
operation only. The DMA Mode bit (bit 
6) must be false (0) in the Mode 
Register (port 2) prior to writing this 
register. 
' 


Reset Parity/Interrupt 
Address 7 (Read Only) - Reading this 
register resets the Parity Error bit (bit 5), 
the Interrupt Request bit (bit 4), and the 
Busy Error bit (bit 2) in the Bus and 
Status Register (port 5). 


ON-CHIP SCSI HARDWARE SUP- 
PORT 
The device allows direct control and 
monitoring of the SCSI Bus by providing 
a latch for each signal. 
Portions of the 
protocol define timings which are much 
too quick for traditional microprocessors 
to control. Therefore, hardware support 
has been provided for DMA transfers, 
bus arbitration, phase change monitor- 
ing, bus disconnection, bus reset, parity 
generation, parity checking, and device 
selection/reselection. 


Arbitration is performed using a bus free 
filter to continuously inspect —BSY. If 
—BSY stays inactive for at least 400 ns, 
then the SCSI Bus is free, and arbitra- 
tion may begin. Arbitration starts if the 
bus is free, -SEL is inactive, and the 
Arbitration bit (port 2, bit 0) is active. 
Once arbitration has started (-BSY as- 
serted), an arbitration delay of 2.2 p.s 
should elapse before the Data Bus can 
be examined to determine if arbitration 
has been won. This delay is imple- 
mented in the control software driver. 
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The VL53C8O is a clockwise device. 
Delays such as bus free delay, bus set 
delay, and bus-settle delay are imple- 
mented using gate delays. These 
delays may differ between devices 
because of inherent process variations, 
but are well,within the proposed ANSI 
X3T9.2 specification (Revision 17). 


INTERRUPTS 
The VL53C8O provides an interrupt 
output (IRQ) to display a task comple- 
tion or an unusual bus event. The use 
of interrupts is optional. They may be 
disabled by resetting the assigned bits 
in the Mode Register (port 2) or the 
Select Enable Register (port 4). 


When an interrupt occurs, the Bus and 
Status Register and the Current SCSI 
Bus Status Register should be read to 
determine which condition caused the 
interrupt. IRQ can be reset simply by 
reading the Reset Parity/Interrupt 
Register (port 7) or by an external chip 
reset (-RESET active for 200 ns). 


When the VL53C8O has been correctly 
initialized, an interrupt will be generated 
if the chip is selected or reselected, if an 
-EOP signal occurs during a DMA 
transfer, if an SCSI Bus reset occurs, if 
a parity error occurs during a data 
transfer, if a bus phase mismatch 
occurs, or if an SCSI Bus disconnection 
takes place. 
Selection/Reselection 
The VL53C8O can generate a select 
interrupt if -SEL is true (1 ), its device ID 
is true (1 ), and -BSY is false for at least 
one bus-settle delay (400 ns). If —l/O is 
active, this should be considered a 
reselect interrupt. The correct ID bit is 
determined by a match in the Select 
Enable Register (pon 4). Only a single 
bit match is necessary to generate an 
interrupt. This interrupt may be 
disabled by writing zeros (0's) into all 
bits of the Select Enable Register. 


If parity is supported, parity should also 
be good during the selection phase. 
Therefore, if the Enable Parity bit (port 
2, bit 5) is active then the Parity Error bit 
should be checked to ensure that a 
proper selection has occurred. The 
Enable Parity Interrupt bit need not be 
set for this interrupt to be generated. 


The proposed SCSI specification also 
requires that no more than two device 
IDs be active during the selection 
processor. To ensure this, the Current 
SCSI Data Register (port O) should be 
read. 


Values for the Bus and Status Register 
(port 5) and the Current SCSI Bus 
Status Register (port 4) are displayed 
below, respectively. 


7 
s 
5 
4 
s 
2 
1 
0 
IIIIIIIIIIEII 
END DMA 
PAR 
INT 
o 
esv -ATN -ACK 
OF RQST ERR nosr MCH ERR 
DMA 
ACT 


7 
e 
5 
4 
e 
2 
1 
0 
IIIIIIEEIIII 
-nsr -esv —REQ-MSG -c/o -vo -set -pee 


End of Process (EOP) Interrupt 
An End of Process signal (—EOP) which 
occurs during a DMA transfer (DMA 
Mode true) will set the End Of DMA 
Status bit (port 5, bit 7) and may 
generate an interrupt if Enable EOP 
Interrupt bit (port 2, bit 3) is true. The 
-EOP pulse will not be recognized (End 
of DMA bit set) unless -EOP, -DACK, 
and either —lOR or -IOW are simultane- 
ously active for at least 100 ns. DMA 
transfers can still occur if —EOP was 
asserted at the correct time. This 
interrupt can be disabled by resetting 
the Enable EOP Interrupt bit. 


Values for the Bus and Status Register 
(port 5) and the Current SCSI Bus 
Status Register (port 4) for this interrupt 
are shown below, respectively. 


7 
6 
5 
4 
3 
2 
1 
0 
IIIIIIIIIIIIIIII 
END 
DMA 
PAR 
INT 
0 
BSY -ATN -ACK 
OF 
RQST ERR ROST MCH 
ERR 
DMA 
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IIIIIIEIIIIIIE 
-est -esv -REO -MSG -c/o -vo -star. -DBP 


The End Of DMA bit is used to deter- 
mine when a block transfer is complete. 
Receive operations are complete when 
there is no data left in the chip and no 
additional handshakes occurring. The 
only exception to this is receiving data 
as an Initiator and the Target opts to 
send additional data for the same 
phase. In this case, -REO goes active 
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and the new data appears in the Input 
Data Register. Since a phase mis- 
match interrupt will not occur, -REO 
and -ACK must be sampled to deter- 
mine that the Target is attempting to 
send more data. 


For send operations, the End Of DMA 
bit is set when the DMA completes its 
transfer, but the SCSI transfer may still 
be in progress. if connected as a 
Target, -REO and -ACK should be 
sampled until both are false. If con- 
nected as an Initiator, a phase change 
interrupt can be used to signal the 
completion of the previous phase. It is 
possible for the Target to request more 
data for the same phase. Then, a 
phase change will not occur and both 
-REO and -ACK must be sampled to 
determine when the last byte was 
transferred. 


SCSI Bus Reset 
The VL53C8O generates an interrupt 
when the -RST signal changes to true. 
The device releases all bus signals 
within a bus clear delay (800 ns) of this 
transition. This interrupt also occurs 
after setting the Assert -RST bit (port 1, 
bit 7). This interrupt cannot be dis- 
abled. (Note: -RST is not latched in bit 
7 of the Current SCSI Bus Status 
Register and may not be active when 
this port is read. For this case, the Bus 
Reset interrupt may be determined by 
default.) 


Values for the Bus and Status Register 
(port 5) and the Current SCSI Bus 
Status Register (port 4) are displayed 
below, respectively. 
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END DMA 
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0 
esv -ATN -ACK 
or RQST ERR RQST MCH ERR 
DMA 
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e 
2 
1 
o 
IIIIEBEEBII 
-nsr -esv -REQ-MSG -c/o -I/O -set -DBP 


Parity Error 
An interrupt is generated for a received 
parity error if the Enable Parity Check 
(bit 5) and the Enable Parity Interrupt 
(bit 4) bits are set (1) in the Mode 
Register (port 2). Parity is checked 
while reading the Current SCSI Data 
Register (port 0) and during a DMA 
receive operation. A parity error can be 
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detected without generating an interrupt 
by disabling the Enable Parity Interrupt 
bit and checking the Parity Error flag 
(port 5, bit 5). 


Values for the Bus and Status Register 
(port 5) and the Current SCSI Bus 
Status Register (port 4) are displayed 
below, respectively. 


7 
6 
5 
4 
3 
2 
1 
0 
IIEIIIIIIIIEII 
END DMA PAR 
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0 
esv -ATN -ACK 
OF 
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DMA 
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0 
IIIIIIEIIEIIII 
-RST -esv -REO -MSG -c/o -vo -set. -DBP 


Bus Phase Mismatch 
The SCSI phase lines contain the 
signals -I/O, -C/D, and -MSG. These 
signals are compared with the corre- 
sponding bits in the Target Command 
Register: Assert —I/O (bit 0), Assert -C/ 
D (bit 1), and Assert -MSG (bit 2). The 
comparison continually occurs, and is 
reflected in the Phase Match bit (bit 3) 
of the Bus and Status Register (port 5). 
An interrupt (IRO) is generated if the 
DMA Mode bit (port 2, bit 1) is active 
and a phase mismatch occurs when 
-REO transitions from false to true. 


A phase mismatch prevents the 
recognition of -REO and also removes 
the chip from the bus during an Initiator 
send operation. -DBO through -DB7, 
and -DBP will not be driven even 
though the Assert Data Bus bit (port 1, 
bit 0) is active. This interrupt is only 
active when connected as an Initiator 
and may be disabled by resetting the 
DMA Mode bit. (Note: It is possible for 
this interrupt to occur when connected 
as a Target if another device is driving 
the phase lines to a different state.) 


Values forthe Bus and Status Register 
(port 5) and the Current SCSI Bus 
Status Register (port 4) are displayed 
below, respectively. 


7 
6 
5 
4 
3 
2 
1 
O 
IIIIIIIIIIIIEII 
END 
DMA 
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Q 
BSY --ATN -ACK 
OF 
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-RST —BSY -REO -MSG -C/D -I/O -SEL -DBP 
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Loss of -BSY 
When the Monitor Busy bit (bit 2) in the 
Mode Register (port 2) is active, an 
interrupt will be generated if the -BSY 
signal goes false for at least one bus- 
settle delay (400 ns). This interrupt 
may be disabled by resetting the 
Monitor Busy bit. Values are displayed 
below for the Bus and Status Register 
and Current SCSI Bus Status Register, 
respectively. 


7 
6 
5 
4 
3 
2 
1 
0 
IIIIIIIIIIIIIIII 
END 
DMA 
PAR 
INT 
0 
BSY -ATN -ACK 
OF 
RQST ERR RQST MCH 
ERR 
DMA 
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IIIIIIEEEIIII 
-RST -BSY —REQ -MSG -C/D 
-VO -SEL -DBP 


RESET CONDITIONS 
There are three reset situations that 
apply to the VL53C80: 


Hardware Chip Reset 
When the signal -RST is active for at 
least 200 ns, the VL53C8O device is re- 
initialized and all internal logic and 
control registers are cleared. This is 
only a chip reset, and does not cause 
and SCSI Bus reset condition. 


SCSI Bus Reset (-RST) Received 
When an SCSI -RST signal is detected, 
an IRO interrupt is generated and a chip 
reset occurs. All internal logic and 
registers are cleared, except for the IRQ 
interrupt latch and the Assert -RST bit 
(bit 7) in the Initiator Command Register 
(port 1). (Note: The -RST signal may 
be sampled by reading the Current 
SCSI Bus Status Register (port 4). This 
signal is not latched and may not be 
present when this port is read.) 


SCSI Bus Reset (-RST) Issued 
If the MPU sets the Assert -RST bit (bit 
7) in the Initiator Command Register 
(port 1), the -RST signal goes active on 
the SCSI Bus and an internal reset 
occurs. All internal logic and registers 
are cleared except for the IRQ interrupt 
latch and the Assert -RST bit (bit 7) in 
the Initiator Command Register (port 1). 
The -RST signal continues to be active 
until the Assert -RST bit is reset or until 
a hardware reset occurs. 


DATA TRANSFERS 
Data may be transferred between SCSI 
Bus devices in one of four modes: 
1) Programmed I/O 
2) Normal DMA 
3) Block Mode DMA 
4) Pseudo DMA. 
The following sections describe these 
modes in detail. (Note: For all data 
transfer operations -DACK and —CS 
can never be active at the same time). 


Programmed I/O Transfers 
Programmed l/O is the most basic form 
of data transfer. The -REO and -ACK 
handshake signals are individually 
examined and asserted by reading and 
writing the appropriate register bits. 
This type of transfer is usually used 
when transferring small blocks of data 
(e.g. command blocks or message and 
status bytes). 


An initiator send operation will begin by 
setting the -C/D, -I/O, and -MSG bits 
in the Target Command Register to the 
correct state so that a phase match 
exists. In addition to the phase match 
condition, it is necessary for the Assert 
Data Bus bit (port 1, bit O) to be true 
and the received l/O signal to be false 
for the VL53C8O to send data. 


For every transfer, the data is loaded to 
the Output Data Register (port 0). The 
MPU then waits for the -REO bit (port 
4, bit 5) to become active. Once -REO 
goes active, the Phase Match bit (port 
5, bit 3) is checked and the Assert 
-ACK bit (port 1, bit 4) is set. The 
-REO bit is sampled until it becomes 
false and the MPU resets the Assert 
-ACK bit to complete the transfer. 


Normal DMA Mode 
DMA transfers are usually used for 
large block transfers. The SCSI chip 
outputs a DMA request (DRO) when- 
ever it is ready for a byte transfer. 
External DMA logic uses this DRO 
signal to generate -DACK and an -IOR 
or an -IOW pulse to the VL53C80. 
DRO becomes inactive when -DACK is 
asserted and -DACK goes inactive 
some time after the minimum read or 
write pulse width. This process is 
repeated for every byte. In this mode, 
-DACK should not be allowed to cycle 
unless a transfer is occuring. 
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Block Mode DMA 
Popular DMA controllers such as the 
9517A provide a Block Mode DMA 
transfer. This type of transfer allows the 
DMA controller to transfer blocks of 
data without giving up the use of the 
Data Bus to the MPU after each byte is 
transferred. This way, faster transfer 
rates are achieved by eliminating the re- 
petitive access and release of the MPU 
Bus. 


If the Block Mode DMA bit (port 2, bit 7) 
is active, the VL53C8O begins the 
transfer by asserting DRO. The DMA 
controller then asserts -DACK for the 
duration of the block transfer. DRO be- 
comes inactive for the remainder of the 
transfer. The READY output can be 
used to control the transfer rate. 


Non-block mode DMA transfers 
terminate when -DACK goes false, 
whereas Block Mode transfers end 
when -IOR or -IOW becomes inactive. 
DMA transfers may be started sooner in 
a Block Mode transfer. 


To obtain the best performance in Block 
Mode operation, the DMA logic should 
use the normal DMA mode interlocking 
handshake. READY is available to 
throttle the DMA transfer, but DRO is 30 
to 40 ns faster than READY, and may 
be used to start the cycle sooner. 


The methods described under “Halting 
a DMA Operation" apply for all DMA 
operations. 


Pseudo DMA Mode 
In order to avoid monitoring and 
asserting the request/acknowledge 
handshake signals for programmed I/O 
transfers, the system may be designed 
to implement a pseudo DMA mode. 
This mode initiated by programming the 
VL53C8O to operating in the DMA 
mode, by using the MPU to emulate the 
DMA handshake. DRO may be 
detected by polling the DMA Request 
bit (bit 6) in the Bus and Status Register 
(port 5), by sampling the signal through 
an external port or by using it to cause a 
MPU interrupt. Once DRO is detected, 
the MPU can perform a read or write 
data transfer. This MPU read/write is 
externally decoded to generate the 
correct -DACK and -IOR or -IOW 
signals. 


6) 


Frequently, external decoding logic is 
needed to generate the VL53C8O —CS 
signal. This same logic may be used to 
generate -DACK at no extra system 
cost and provide an increased perform- 
ance in programmed I/O transfers. 


Haltlng a DMA Operation 
The -EOP signal is one way to halt a 
DMA transfer. A bus phase mismatch 
or a reset of the DMA Mode bit (port 2, 
bit 1) can also end a DMA cycle for the 
current bus phase. 


Using the —EOP Signal - If —EOP is 
used, it should be asserted for at least 
100 ns while -DACK and -IOR or -IOW 
are both active. If either-IOR or -IOW 
are not active, an interrupt will be gen- 
erated, but the DMA activity will 
continue. The -EOP signal does not 
reset the DMA Mode bit. The -EOP 
signal can occur during the last byte 
sent to the Output Data Register (port 
0). The —REQ and -ACK signals should 
be monitored to ensure that the last 
byte has transferred. 
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Bus Phase Mismatch Interrupt - A bus 
phase mismatch interrupt may be used 
to halt the transfer if operating as an 
Initiator. Using this method frees the 
host from maintaining a data length 
counter and frees the DMA logic from 
providing the —EOP signal. If perform- 
ing an Initiator send operation, the 
VL53C8O requires -DACK to cycle 
before -ACK goes inactive. Since 
phase changes cannot occur if -ACK is 
active, either -DACK must be cycled 
after the last byte is sent or the DMA 
Mode bit must be reset in order to 
receive the phase mismatch interrupt. 


Resetting the DMA Mode Bit - A DMA 
operation may be stopped at any time 
simplyby resetting the DMA Mode bit. 
It is recommended that the DMA Mode 
bit be reset after receiving an -EOP or 
bus phase mismatch interrupt. The 
DMA Mode bit must then be set before 
writing any of the start DMA register for 
later bus phases. 
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If resetting the DMA Mode bit is used 
instead of —EOP for Target role 
operation, then care must be exercised 
to reset this bit at the proper time. 
When receiving data as a Target 
device, the DMA Mode bit must be reset 
once the last DRO is received and 
before -DACK is asserted to prevent an 
additional —REQ from taking place. Re- 
setting this bit causes DRO to go 
inactive. The last byte received 
remains in the Input Data Register and 
may be obtained either by performing a 
normal MPU read or by cycling -DACK 
or-IOR. Frequently, -EOP is easierto 
use when operating as a Target device. 
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. 
VL53C8O 


SWITCHING TEST CIRCUIT 


A 
IOLl 


VT 


50pF 
I 
ov 
Q1 IOL 
9 


SWITCHING TEST WAVEFORM 


2.4 
2.0> 
< 2.0 
' 


0.8 
0.8 
0.4 
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VL53C8O 


SWITCHING CHARACTERISTICS/WAVEFORMS 


CPU wane 


Symbol 
Description 
@ 
Condition 
, 


t1 
Address Setup to Write Enable 
Write Enable Occurs When -IOW and -CS 


12 
Write Enable Occurs When -IOW and -cs 


t3 
Write Enable Occurs When -IOW and —CS 


*4 
IIIE 
t5 
Write Enable Occurs When -IOW and -CS 


*6 
IE 


A0-A2 


t1 
t2 


-CS 


C) 
i 


I3 
I4 


-IOW 


I5 
I6 
°°-D’ 
, 


CPU READ 
Symbol 
%@@ 
Condiiion 
t1 
_ 
Read Enable Occurs When -IOR and —CS 


t2 
Read Enable Occurs When —lOR and -cs 


*3 
11$ 
t4 
Read Enable Occurs When —lOR and —CS 


*5 
IE 


A°-A2 


-CS 


t3 


—IOR 


t4 
15 


°° - D’/ . ./Z 
/ _”4//’ 
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SWITCHING CHARACTERISTICS/WAVEFORMS(Cont.) 


DMA WRITE (NON-BLOCK MODE) TARGET SE 


Description 
Symbol 
n 


12 


t3 


14 


t5 


t6 


17 


t8 


t9 


t10 


t11 


I12 


113 


6 


E58O 


00 C) 
DRO False 


-DACK False 


-DACK True 


to DRO True 


Write Enable Width 
IIIE 
EIE 
III1 
I1 
E1 
B 
E3 


(-DACK False) 
EB 
31$ 
EIE 


from 


VL53C8O 


Condition 


Write Enable Occurs When -IOW and -DACK 


Write Enable Occurs When -IOW and -DACK 


Note: —EOP, --IOW, and -DACK must be concurrently true for at least t7 for proper recognition of the —EOP pulse. 


DRO 


-DACK 


-Knu 


oo-o7 


—EOP 


—REQ 


-ACK 


-DBP 


t1 
12 


7% 
BYTE N 
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I9 


t11 


n2 
us 
-DBO - —DB7, 
BYTE N-1 
» 
BYTE N 
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SWITCHING CHARACTERISTICS/WAVEFORMS(Cont.) 


DMA WRITE (NON-BLOCK MODE) INITIATOR SENU 


VL53C80 


Symbol 
Description 
E Condition 


I1 


e-0-re-0-0-v-ov-0-e-0-0(D@NCTU'|-§(DI\) 


I10 


111 


112 


DRO False from 


-DACK False to DRO True 


Write Enable Width 
IIIE 
11$ 
IIIE 
IE 
HIE 
E1 
E 
11 
IE 


-DACK True 


.-L @ C) 


-A(A) C) 


Write Enable Occurs When -IOW and -DACK 


Write Enable Occurs When -IOW and -DACK 


Note: —EOP, -IOW, and -DACK must be concurrently true for at least t7 for proper recognition of the -EOP pulse. 


DRO 


-DACK 


-IOW 


D0 - D7 


—EOP 


-REO 


-ACK 


I1 
I2 
in@151 


I 
. 
BYTE N 


I 
112 
111 
’ 


£32 - -DB7, 
BYTE N-1 
/ 
BYTE N 
I 
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SWITCHING CHARACTERISTICS/WAVEFQRMS(Cont.) 


DMA READ (NON-BLOCK MODE) TARGET RECEIVE 


Symbol 


t1 


u-0-v-O:-0;-0|-0-v-0 \lO3U1-P0070 


l8 


I9 


I10 


I11 


H2 


Descrlptlon 


DRO False from -DACK True 


-DACK False to DRO True IIIE 
IE 
E13 
EH13 
IHIIE 


(-ACK False) 
EE 


(-DACK False) 
EH 
IE 
11$ 


-5 CD (D 


VL53C8O 


Condltlon 


Read Enable Occurs When -IOR and -DACK 


Note: —EOP, -IOR, and -DACK must be concurrently true for at least t6 for proper recognition of the —EOP pulse. 


DRO 


-DACK 


-IOR 


D0 - D7 


—EOP 


—REQ 


-ACK 


\igil§ \ 
¢ 


I12 
I11 
2333' DB7’ 
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SWITCHING CHARACTERISTICS/WAVEFOHMS(Cont.) 


DMA READ (NON-BLOCK MODE) INITIATOR REC 


Symbol 


t1 


a-on-0-4-0-u-0--0-a-0 \lO7U1-P(AJl'\J 


18 


19 


t10 


111 


112 


wm°< 


m 


O0O 


Descrlptlon 


DRQ False from -DACK True 


-DACK False to DRQ True 


-DACK Hold 
End of --IO 


Read Enable 


Data Hold TllTl8 from End of -IOR 


Wrdth of —EOP Pulse (Note) 


—REQ True to DRO True 


-DACK False to -ACK False 
(—REQ False) 


—REQ True to -ACK True 


—REQ False to -ACK False 
(-DACK False) 


Tlme from 


l'\) 
l'\) QQ 
-5U1 CD 


Data Access '|"|me from 


Data Setup Tlme to —REQ 


Data Hold TllTl8 from —REQ 


Conditlon 


Read Enable 


VL53C8O 


Occurs When —lOR and -DACK 


Note: -EOP, -IOH, and -DACK must be concurrently true for at least t6 for proper recognition of the —EOP pulse. 


DRO 


-DACK 


-IOR 


D0 - D7 


—EOP 


—REQ 


-ACK 


-DBO - -DB7, 
-DBP 


11 
12 


s '1 
BYTE N 


17 
t8 


t11 
l 
t12 


220 


W VLSI TECHNOLOGY; INC. 


SWITCHING CHARACTERISTICS/WAVEFORMS(com) 


DMA WRITE (BLOCK MODE) TARGET SEND 


Symbol 


t1 


a-or-0-0-0-0--0 \lO3U14>OOI\) 


18 


t9 


I10 


I11 


I12 


t13 


'\)-1.-1. 


Q 
l\J 


-5 CD Q 


Descrlptlon 


DRO False from -DACK True 


Write Enable Width 


Wrlte Recovery Tlme 


Data Setup to End of Wrlte Enable 


Data Hold Tlme from End of -IOW 


Width 


OO 


—L-LQ\lOQ 


of -EOP Pulse (Note) 


-ACK True to -REO False 


-REO from End of -ACK 
(-ACK False) 


-REO from End of -ACK 
(-IOW False) 


-ACK True to READY True 


READY True to -IOW False 


-IOW False to READY 


Data Hold from -ACK True 


Dat 


False 


u 
o - 


VL53C8O 


Condltlon 


E 


E 


rite Enable Occurs When -IOW and -DACK 


rite Enable Occurs When -IOW and -DACK 


114 
a Set pt 
REO True 


Note: —EOP, -IOW, and -DACK must be concurrently true for at least t6 for proper recognition of the —EOP pulse. 


t1 1 
DRO 


-DACK 


-IOW 


D0 - D7 


—EOP 


-REO 


-ACK 


READY 


BYTE N 


13 


I352 ' “D-B7’ 
BYTE $13 
M 
BYTE N 
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SWITCHING CHARACTERISTICS/WAVEFORMS(Cont.) 


DMA READ (BLOCK MODE) TARGET RECEIVE 


Description 
Symbol 


t1 


12 


-0|-0--0U1-#0) 


16 


17 


18 


19 


110 


111 


112 


113 


@ 


-5-5-5-5 -§ 
\| 
|\) 
(A)@ 
@ 
U1 
@ 


DRO False from -DACK True 


IO C) 
-IOR Recovery Tlme 


Data Access Tlme from 


Data Hold Tlme from End of —lOR 


Wld1h of -EOP Pulse (Note) 


—lOR False to -RE 


Read Enable 


O True 
(-ACK False) 


-ACK True to -REO False 


-ACK False to —REQ True 
(—lOR False) 


-ACK True to READY True 


READY true to Valld Data 
1 
QB 
EIZE 


VL53C8O 


Conditlon 


IIead Enable Occurs When -IOR and -DACK 


Note: -EOP, -IOR, and -DACK must be concurrently true for at least t5 for proper recognition of the -EOP pulse. 


t1 1 
DRO 


-DACK 


--IOR 


D0 - D7 


—EOP 


—REQ 


-ACK 


READY 


12 
in 
“ 


18 


19 
110 
111 
_ 
-oeo--can 
_DBP 
BYTE N 
/ 
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SWITCHING CHARACTERISTICS/WAVEFORMS(Cont.) 


RESET 


Symbol 
Descrlptlon 
Condltlon 


11 
Minimum Width of Reset 
200 


'REsET _i1ij 


ARBITRATION 


Symbol 
%%@ 
<=~="<*"'==" 
" 
—@E 
*2 
@ 
*3 
-E 


._R3T 


-SEL 


11 


--BSY 
12 


Iggg ' —DB7‘ 
2». 
at 


ARB 
ta 


-BSY (IN) 
i-—---_i-i-1--/' W 
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VL53C8O 


ABSOLUTE MAXIMUM RATINGS 


Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. 
Temperature 
0°C to +70°C 
permanent damage to the device. 
Exposure to absolute maximum rating 
Storage Temperature _65,,C to +1 50,0 
These.are stress ratings only, functional 
conditions for e>ttended periods may 
operation of this device at these or any 
affect device reliability. 
SUPPIY V°|1a9° 1° 
other conditions above those indicated 
Ground Potential 
+6 V 


Applied Input 
Voltage 
-0.6 V to VCC +0.6 V 


Power Dissipation 
0.8 W 


DC CHARACTERISTICS: TA = o=>c to +7o=>c, vcc = s v 15% 


“H 
E 
“L 
3% 
IIH 
High Level Input Current on: 
VIH = 5.25 V, VIL = 0 


SCSI Bus Pins 


All Other Pins 


IIL 
Low Level Input Current on 
VIH = 5.25 V, VIL = 0 


A"°*“e'P*"S 
Zltl 
VOH 
High Level Output Voltage 
I 
voo = 4.75 v, IOH = -3.0 mA 


VOL 
Low Level Output Voltage on: 
scsi Bus Pins" 
vop = 4.75 v, IOL = 48.0 mA 


All Other Pins 
v00 = 4.75 v, lOL = 7.0 mA 
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CMOS 8-BIT MICROPROCESSOR 


FEATURES 
DESCRIPTION 


- CMOS silicon-gate technology 
The VL65NC02 is an 8-bit micro- 
Low 
owe‘, 
processor device produced using CMOS 


1 1p A/MH 
silicon-gate technology. This device 
_ 
' 
m 
Z 
provides advanced system architecture 
- Software compatible with the NMOS 
for enhancements in system perform- 
6502 
ance, speed, and value over its NMOS 
counterparts, the 65XX family of 
Single 5 V power suppiy '°q“i'°d 
microprocessor devices. The VL65NC02 
. 3-b;t pa,a||e| processing 
is the CMOS equivalent of the NMOS 
6502, and contains some enhance- 
' Twe indexing capabmw 
ments. This CMOS type may exhibit 
. programmable stack pointer 
different intermediate cycle information 
from that resident in the NMOS 6502. 
I"1°""PI¢aPabI|IIY 
Intermediate cycle information is not 
, Nonmaskable interrupt 
specified, and should not be used. 


' 
3-511 bldiledioal (I818 bus 
The VL65NC02 provides 64K bytes of 
, Addressable memory range O, up to 
addressable memory and an interrupt 
64K bytes 
input, as well as options for on-chip 
oscillators and drivers. 
It is bus and 
' Ready input 
software compatible with the 65XX CPU 
' Direct memory access (DMA) 
family’ 
capability 
CLOCKGENERATOR 
The clock generator develops all internal 
Clock speeds up 1° 4 MHZ 
clock signals and (where applicable) 
. pipeiined architemure 
external clock signals associated with 


' O"'°hip °l°°k °pIi°"s= 
drives the timing control unit and the 
'EXt°ma| Si"9l°'i"Put °|°°k 
external timing for slave mode 
-On-board clock, single external 
operatic,“ 
crystal 


the device. It is the clock generator that 


TIMING CONTROL 
The timing control unit keeps track of 
the instruction cycle being monitored. 
The unit is set to zero each time an 
instruction fetch is executed and is 
advanced at the beginning of each 
phase-one clock pulse for as many 
cycles as are required to complete the 
instruction. Each data transfer that 
takes place between the registers 
depends upon decoding the contents of 
both the instruction register and the 
timing control unit. 


PROGRAM COUNTER 
The 16-bit program counter provides the 
addresses that step the microprocessor 
through sequential instructions in a 
program. 


Each time the microprocessor fetches 
an instruction from program memory, 
the lower byte of the program counter 
(PCL) is placed on the low-order bits of 
the address bus and the higher byte of 
the program counter (PCH) is placed on 
the high-order 8 bits. The counter is 
incremented each time an instruction or 
data is fetched from program memory. 


PIN DIAGRAM 
ORDER INFORMATION 


VL65NC02 
-PM 
Clock 


vss 
RDY 
rat (OUT) 
-IRQ 
N.C. 
—NMl 
SYNC 
vcc 
A0 
A1 
A2 
A3 
A4 
A5 
A6 
A7 
A8 
A9 
A10 
A11 


OI-b(0l\I-5 
6 
7 
8 
9 


40 I 
39 
38 I 
37 I 
36 I 
N.C. 
35 I 
N.C. 
34 I 
33 I 
32 I 


S.O. 


10 
31 I 


12 
29 I 
13 
28 I 
14 
27 I 
D6 
15 
26 I 
16 
25 I 
17 
24 I 


D1 
D2 
11 
30 I 
D3 
D4 
D5 


D7 
A15 
A14 
18 
23 I 
A13 
19 
22 I 
A12 
20 
21 I 
VSS 


Number 


-RES 
VL65NC02-01PC 


VL65NC02-01CC 


VL65NC02-02PC 


I36-W 
VL65NC02-02CC 


VL65NCO2-03PC 


VL65NC02-03CC 


VL65NC02-04PC 


VL65NC02-04CC 


I oz (OUT) 


eo, (IN) 


Frequency 
Package 


Plastic DIP 


Ceramic DIP 


Plastic DIP 


Ceramic DIP 


Plastic DIP 


Ceramic DIP 


Plastic DIP 


Ceramic DIP 


Note: Operating temperature range is 0°C to +70°C. 
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BLOCK DIAGRAM 


ADDRESS 
BUS 


INTERNAL ARCHITECTURE 


VL65NC02 


<i—-— 
REGISTER SECTION 
CONTROL SECTION —-—i'> 


A0 


A3 
ABL 


A4 


A5 


A6 
III 
"I 
III 


A7 


A8 
ACCUMULATO 


A9 


A10 
POLiIi 


A11 


I 
-RES-IRQ -NMI 


INDEX 
4-; 
REG'STEF‘ P“ 
" 
INTERRUPT 
A1 
Y 
LOGIC 


INDEX 
4-P 
A2 
REGISTER ~ 
X 
RDY 


STACK 
._, 
SYNC 
i 
POINT 
w 


I HI 
DECODE 
ALU 
I 


REGISTER ts) 


INSTRUCTION 


4-P 
PROCE 


TIMING 
CONTROL 


CLOCK 
STATUS 
GENERATOR 
ABH 
REGISTER P 
A12 


NPUT DATA 
A13 
LATCH (DL) 


A14 


DATA BUS 
A15 
BUFFER 


LEGEND‘ 
H 
<: 
8 BIT LINE 
—-' 
1 BIT LINE 
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==tE—‘i. TIE!-5I 
H 
IIIIIH 
D0 
D1 
D2 
D3 
DATA 
D4 
BUS 
D5 
D6 
D7 


00, (IN) 


01, OUT 


O2, OUT 
1: 
SO 


INSTRUCTION 
REGISTER 


R/—W 
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TABLE 1. HARDWARE ENHANCEMENTS 


The VL65NC02 microprocessor has 
been designed with several hardware 
and software enhancements over the 
NMOS 6502 device, while maintaining 
_ 
, 
_ 
software compatability. In addition to the 
Pm °°mpaI'b|° wnh NMOS 6502 
I"¢l°a$9d $9995 and I°W°I P°W9f 
64K addressable bytes of memory 
consumption inherent in CMOS technol- 
. 
ogy, the VL65NC02 has the following 
TIRQ menum 
characteristics: 
TTL-level single phase clock input 


VL65NC02 Enhancements 


- Two new addressing modes 
RC time base clock input 


- Seven software/operational 
Crystal time base clock input 


enhancements 
Two-phase output clock 


SYNC and RDY signals 


-NMI interrupt signal 


- Two hardware enhancements: 


— Eight new instructions, 64 total 
— 27 new opcodes, 178 total 


SIGNAL DESCRIPTIONS 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


O0 (IN), 
37. 
Clock Signals - The VL65NC02 requires an external O0 clock. O0 is a TTL-level input 
O1 (OUT), 
3, 39 
that is used to generate the internal clocks of the VL65NC02. Two full-level output 
O2 (OUT) 
clocks are generated by the VL65NCO2. The O2 clock is in phase with O0. The O1 
clock output is 180° out of phase with O0. When O0 is stopped, the CPU is in the 
standby mode. 


-IRQ 
4 
Interrupt Request - This TTL-compatible input requests that an interrupt sequence begin 
within the microprocessor. The -IRQ is sampled during Q12 operation; if the interrupt flag 
in the processor status register is zero, the current instruction is completed and the 
interrupt sequence begins during O1. The program counter and processor status 
register are stored in the stack. The microprocessor then sets the interrupt mask flag 
high so that no further -lROs may occur. At the end of this cycle, the program counter 
low byte is loaded from address FFFE, and program counter high byte from location 
FFFF, thus transferring program control to the memory vector located at these ad- 
dresses. The RDY signal must be in the high state for any interrupt to be recognized. A 
3 k.Q external resistor should be used for proper wire-OR operation. 
-NMI 
6 
Non-Maskable Interrupt - A negative-going edge on this input requests that a non-mas- 
kable interrupt sequence be generated within the microprocessor. The -NMI is sampled 
during O2; the current instruction is completed and the interrupt sequence begins during 
O1. The program counter is loaded with the interrupt vector from locations FFFA (low 
byte) and FFFB (high byte), thereby transferring program control to the non-maskable 
interrupt routine. Since this interrupt is non-maskable, another -NMI can occur before 
the first is finished. Care should be taken when using —NMl to avoid this. 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


RDY 
2 
Ready - This input allows the user to single-cycle the microprocessor on all cycles, 
including write cycles. A negative transition to the low state, during or coincident with 
O1, halts the microprocessor with the output address lines reflecting the current address 
being fetched. This condition remains through a subsequent O2 in which the ready 
signal is low. This feature allows microprocessor interfacing with low-speed memory as 
well as direct memory access (DMA). 


R/—W 
34 
Read/Write - This signal is normally in the high state, indicating that the microprocessor 
is reading data from memory or I/O bus. In the low state, the data bus has valid data 
from the microprocessor to be stored at the addressed memory location. 


—SO 
38 
Set Overflow - A negative transition on this line sets the overflow bit (V) in the processor 
status register. The signal is sampled prior to the leading edge of O2 by the processor 
control time (tRWS). 


-RES 
40 
Reset - This input resets the microprocessor. Reset must be held low for at least two 
clock cycles after VCC reaches operating voltage from a power-down. A positive transi- 
tion on this pin causes an initialization sequence to begin. Likewise, after the system 
has been operating, a low on this line of at least two cycles ceases microprocessing 
activity, followed by initialization after the positive edge on —RES. 


When a positive edge is detected, there is an initialization sequence lasting six clock 
cycles. Then, the interrupt mask flag is set, the decimal mode is cleared, and the 
' 
program counter is loaded with the restart vector from locations FFFC (low byte) and 
FFFD (high byte). This is the start location for program control. This input should be 
high in normal operation. 


SYNC 
7 
Synchronize - This output line identifies those cycles during which the microprocessor is 
fetching the instruction operation code (op code). The SYNC line goes high during O1 of 
an opoode fetch and stays high for the remainder of that cycle. If the RDY line is pulled 
low during the O1 clock pulse in which SYNC went high, the processor stops in its 
current state and remains in the state until the RDY line goes high. In this manner, the 
SYNC signal can be used to control RDY to cause single instruction execution. 


A0 - A15 
9 - 25 
Address Bus - A0-A15 forms a 16-bit address bus for memory and I/O exchanges on the 
data bus. The output of each address line is TTL-compatible, capable of driving one 
standard TTL load and 130 pF. 
' 


D0 - D7 
33 - 26 
Data Bus - The data lines constitute an 8-bit bidirectional data bus used for data ex- 
changes to and from the device and peripherals. The outputs are three-state buffers 
capable of driving one 1TLIoad and 130 pF. 


VCC 
8 
5 V :t 5% power supply 


VSS 
1.21 
Digital ground 
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INSTRUCTION AND 
REGISTER DECO DE 
Instructions fetched from memory are 
gated onto the internal data bus. These 
instructions are latched into the instruc- 
tion register, then decoded, along with 
timing and interrupt signals, to generate 
control signals for the various registers. 


ARITHMETIC/LOGIC UNIT 
All arithmetic and logic operations take 
place in the ALU, including incrementing 
and decrementing internal registers 
(except the program counter). The ALU 
has no internal memory and is used only 
to perform logical and transient numeri- 
cal operations. 


ACCUMULATOR 
The accumulator is a general-purpose 8- 
bit register that stores the results of 
most arithmetic and logic operations. In 
addition, the accumulator usually 
contains one of the two data words used 
in these operations. 


INDEX REGISTER 
There are two 8-bit index registers (X 
and Y) that may be used to count 
program steps or to provide an index 
value to be used in generating an 
effective address. 


When executing an instruction that 
specifies indexed addressing, theCPU 
fetches the op code and the base 
address, and modifies the address by 
adding the index register to it prior to 
performing the desired operation. Pre- 
or post-indexing of indirect addresses is 
possible (see addressing modes). 


STACK POINTER 
The stack pointer is an 8-bit register 
used to control the addressing of the 
variable-length stack on page one. The 
stack pointer is automatically incre- 
mented and decremented under control 
of the microprocessor to perform stack 
manipulations under direction of either 
the program or interrupts (-NMI and 
-IRQ). The stack allows simple implem- 
entation of nested sub-routines and 
mulitple-level interrupts. The stack 
pointer should be initialized before any 
interrupts or stack operations occur. 


PROCESSOR STATUS REGISTER 


The 8-bit processor status register con- 
tains seven status flags. Some of the 
flags are controlled by the program, 
others may be controlled by the program 
and the CPU. The VL65NC02 instruc- 


VL65NC02 


tion set contains a number of conditional 
branch instructions that are designed to 
allow testing of these flags. 


HARDWARE ENHANCEMENTS 
The VL65NC02 microprocessor 
incorporates several hardware en- 
hancements over its NMOS counterpart, 
the 6502. These hardware enhance- 
ments are: 


- The NMOS device would ignore the 
assertion of a Ready (RDY) during a 
write operation. The CMOS family 
stops the processor during O2 clock 
if RDY is asserted during a write 
operation. 


- On the NMOS device, unused input- 
only pins (-IRQ, -NMI, RDY, -RES, 
and -SO) must be connected to a low 
impedance signal to avoid noise 
problems. These unused pins on the 
CMOS devices are internally con- 
nected by a high-impedance to 
VCC (approximately 250 kn). 


OPERATIONAL ENHANCEMENTS 
Tables 1 lists the operational enhance- 
ments that have been added to the 
VL65NC02 device. 


TABLE 2. NO OPERATION (NOP) TIMING FOR UNDEFINED OPCODES 


Number of Bytes Expected 
Number of 
Qpggde 
(TotaI- Including Opcode): 
Cycles: 


X2 


(.DCOCOI\)I\JI\)I\)—-\-\-\-*l\) 


X3 
X7 
XB 
XF 
44 
54 
D4 
F4 
5C 
DC 
FC 


Note: "X" indicates a "Don‘t Care‘. 


-5-Rm-R-P-PCO—*-*-*-*l\) 
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TABLE 3. INSTRUCTION SET SUMMARY 


_ 
*7. 
. 
__ 
' 
_ 
_ 
_ 
7 
7 
— 
7. 
1' 
'Jq 
. 
I 
I 
.. 
__ 
lMME- 
ABSO- 
zERo 
<4) 
(1) 
(1) 
(1) 
_ 
- 
- 


0 
H 
oiATE 
i.u_TE 
PAGE, IMPLIED (INQ. X,I_ iINo).Y 
ZPG.X 
ABS,X 
1ABS,Y TlVEl2l 
REcT 
ZPG,Y STATUS CODE 
_ 
._ 
_ 
. 
. 
F 
, 
2 - 
. 


RELA 
INDI 
PROCESSOR 


MNE- 
7643210 
MNE- 


ADC 
AND 
ASL 
BCC 
BCS 


A+M+c~A 
wt 
AA M ~ A 
c -I7 
0] -0 
I BRANCH IF c=o (2) 
LBRANCHIF c=t (2) 


69:22 6D43I6 
2922 2D43 
2 
I 
OE63 
I 
I 
‘ 
52 
OA 2| t 
I 
1552153 
I 


7152754 
If 
379433 
at52 
54 
3943 
3252 
N0000ZC 


Fj 
CJ¢O_o__o row 
toro 


ADC 
AND 
ASL 
BCC 
BCS, 


_MONlC _ 
OPERATION 
OPIn# OPn# OPnlf OP nI# OP|nIlf0Pn# OPn# O_Pn# Q_Pn# OFJnlf OPnl_f OPn#NVBDIZC MONIC 
32 
I 
GIIGI2 
7 
27 
43 
I 
7252 
NV¢"ZC 
I 
52 
2152 
s 
23 
4a 
N----z- 


BEo 
BIT 
BMI 
BNE 


g BPL 


I I 
~ I 
I BRANcH IF z=t (2) 
I A A M 
(5) 
BRANcH IF N=1(2) 
I BRANCH IF z=o (2) 
I 
I 
| BRANCH IF N=0(2) 


on Toto to 
toO :- 
co 
to:- 32 


In ___i,‘r-. 
. 
_ 
._. 
_ _ 
~_- - ' 3:.- 


I 
I 
2 
0000000 
344 
M1Mo¢'¢Z' 
ro 
coO at 
ca 
83 


*-11- 


MNto 
row 


~ 
I‘ 
’°°* 
' 
::::::: 


BEQ 
BIT 
BMI 
BNE 
BPL 
BRA 
BRK 
Bvc 
Bvs 
CLC 
S19 


__ 


I 


i 
iz- 


Zi‘rd 


BRANcHALwAYs(2)‘k 
TIT 
C 
IBREAK 
BRANCH tr v=o (2) 
' 
BRANCH IF v=1 (2) 
I 


10 


8 


18 
D8 


T‘-I 


ION) 
-5-0 


I 
. 
{I 
Iwl 


'4I7_7 
T 
I 
. 
_ 
" 
' 
_ 
T. 
"1 
0 
77 
'2 
' 
' 
7 
O 
O 
O 
O 
O 
O 
O 


I 
0010100 


u 
0000000 


--I 
‘F-" 
-—-— 
T-— 


N 
D-I 
__O 
O_O 
ION) 
ION) 
ION 
I\)I\J 
0000000 


| 
0000000 
000Q000 
cu 
CLV 
CMP 
CPX 
CPY 


0-0 
I°" 
A-M 
43lC5 
I 
43 
- 
4a_, 


i‘ 
L7 


— 


I 


—-I 
-17 
its 
iii 
_ 


<>.<ii 


<_ 


OmOooro 
REEL NNN 
him! OmOO00 
‘E4 3|2 
C432 


I 


3'2 


sBI 
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—l—l: 
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I 
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N--- 


I 
I 
| 
I 
I 
I 
II 
I 
IN 
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BRK 
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BVS 
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CLO 
.12 
_4 
_ 
~ 
_ 
I 
A 
-I4. 


I 
I 


F‘ 
I 
J 
I 
0000000 


I 
- 
I 
Q000E(0: 


'ZC 
~ZC 


I'- 


CLI 
CLV 
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CPY_ 
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DEX 
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EOR 
INC 


DECREMENT 
x-1 - x 
Y-1 - Y 
A v M —~A 
INCREMENT 


I Ice 5 s I cs 


F 
l 


49|2|2 4o 4 3 


g 
g 
WEE 
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I 


| 
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I 
j_ 
_ 
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_ 
_- 
_~ 
- 
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I 
I 
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N 


I 
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IN 
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I 
I 
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000020 


_ 
_ 
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000020 
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A 
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000020 
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DEX 
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EOR 
INC 


INX 
INY 
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LDA 


, 
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, 
F, 
— 
x+t-x 
(I 
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I 
JUMP To NEWLOC 
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O) 
>at 08¢) 


I4s|a 2 
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C) 
IO 


C8 
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I 
‘ 
8821 
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N‘ 
° ' '2' 


I 
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I 
t 
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I 
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N 


*1 
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| 
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III0000000 


I 
‘I 
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, 
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N 


H 
0000z0 
II 
Y 
.2 
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I 
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O 
INX 
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LDA 
LDX 
LDY 
i_sR 
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ORA. 
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_ 
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0 
M—-X 
A2 2 2 


-15- 
>> 
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A6 
I M - v 
‘A0 2 
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~¢ 
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l“~ 
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I 
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llI~0000Z0 
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‘O 
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B) 
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' 
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TABLE 4. INSTRUCTION SET SUMMARY ABBREVIATIONS 


X 
Index X 
Y 
Index Y 
A 
Accumulator 
M 
Memor 
erEffective Address 
Ms Memo 
erstack Pointer 
+ 
Add 
- 
Subtract 


A 
And 
Y 
|- 
Exclusive Or 
Numberof C cles 
NumberofB es 
M6 Memor Bit6 
M7 Memor Bit7 


nag; 


Add 1 to "n" if decimal mode, if page 
boundary is crossed (except STA and 
STZ), or if branch on same page (add 2 
if page different). Accumulator address 
os included in implied address. "N" and 
“V" ags are unchanged in immediate 
mode. “Z“ flag includes AAM 
result (same as BIT instruction). 


ADDRESSING MODES 
The VL65NC02 CPU has 15 addressing 
modes (two more than the NMOS- 
equivalent family). In the following 
discussion of these addressing modes, 
a bracketed expression follows the title 
of the mode. This expression is the 
term used in the Instruction Set Opcode 
Matrix, Table 8, to make it easier to 
identify the actual addressing mode 
used by the instruction. 


ACCUMULATOR ADDRESSING 
[Accum]- This form of addressing is 
represented by a one-byte instruction, 
implying an operation on the accumula- 
tor. 


IMMEDIATE ADDRESSING 
[IMM] - In immediate addressing, the 
second byte of the instruction contains 
the operand, with no further memory 
addressing required. 


ABSOLUTEADDRESSING 
[Absolute] - In absolute addressing, the 
second byte of the instruction specifies 
the eight low-order bits of the effective 
address, while the third byte specifies 
the eight high-order bits. Thus, the 
absolute addressing mode allows 
access to the entire 64K bytes of 
addressable memory. 


ZERO PAGE ADDRESSING 
[ZP] - The zero page instructions allow 
for shorter code and execution times by 
fetching only the second byte of the 
instruction and assuming a zero high 
address byte. Careful use of the zero- 
page can result in a significant increase 
in code efficiency. 


INDEXED ZERO PAGED ADDRESS- 
ING 
[ZP, X, or Y] - (X, Y Indexing) - This 
form of addressing is used with the 
index register and is referred to as 
‘zero-page, X” or ‘zero-page, Y”. The 
effective address is calculated by adding 
the second byte to the contents of the 
index register. Since this is a form of 
“zero-page" addressing, the content of 


the second byte references a location in 
page zero. Additionally, due to the 
‘zero-page“ addressing nature of this 
mode, no carry is added to the high- 
order eight bits of memory and crossing 
of page boundaries does not occur. 


INDEXED ABSOLUTE ADDRESSING 
[ABS, X, or Y] - (X, Y Indexing) - This 
form of addressing is used in conjunc- 
tion with X and Y index register and is 
referred to as ‘absolute, X‘ and 
"absolute, Y“. The effective address is 
formed by adding the contents of X or Y 
to the address contained in the second 
and third bytes of the instruction. This 
mode allows the index register to 
contain the index or count value and the 
instruction to contain the base address. 
This type of indexing allows any location 
referencing and the index to modify 
multiple fields, resulting in reduced 
coding and execution time. 


INDEXED ABSOLUTE INDIRECT 
[(IND), X] - (JMP (IND), X) - The 
contents of the second and third 
instruction bytes are added to the X 
register. The 16-bit result is a memory 
address containing the effective 
address. 


IMPLIED ADDRESSING 
[Implied] - In the implied addressing 
mode, the address containing the 
operand is implicity stated in the 
operation code of the instruction. 


RELATIVEADDRESSING 
[Relative] - Relative addressing is used 
only with branch instructions and 
establishes a destination for the 
conditional branch. 


The second byte of the instruction 
becomes the operand, which is an 
"offset" added to the contents of the 
lower eight bits of the program counter 
when the counter is set at the next 
instruction. The 8-bit offset provides a 
branching range of -128 to +127 bytes 
from the next instruction. 
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INDEXED INDIRECT ADDRESSING 
[(lND, X)] - In indexed indirect address- 
ing, referred to as indirect, X, the 
second byte of the instruction is added 
to the contents of the X index register, 
discarding the carry. The result of this 
addition points to a memory location on 
page zero whose contents are the low- 
order eight bits of the effective address. 
The next memory location in page zero 
contains the high-order eight bits of the 
effective address. Both memory 
locations specifying the high-and Iow- 
order bytes of the effective address 
must be in page zero. 


INDIRECT INDEXED ADDRESSING 
[(IND), Y] - In indirect indexed address- 
ing. referred to as indirect, Y, the 
second byte of the instruction points to ya 
memory location in page zero. The 
contents of this memory location are 
added to the contents of the Y index 
register, the result being the low-order 
eight bits of the effective address. The 
carry from this addition is added to the 
contents of the next page zero memory 
location, the result being the high-order 
eight bits of the effective address. 


ABSOLUTEINDIRECT 
[Indirect] - The second byte of the 
instruction contains the low-order eight 
bits of a memory location. The high- 
order eight bits of that memory location 
are contained in the third byte of the 
instruction. The contents of the fully 
specified memory location are the low- 
order byte of the effective address. The 
next memory location contains the high- 
order byte of the effective address, 
which is loaded into the 16 bits of the 
program counter, (JMP (IND) only). 


INDIRECT 
[(lND)] - The second byte of the 
instruction contains a zero page address 
serving as the indirect pointer. This is 
not available on the NMOS 6500 family. 


® VLSI TECHNOLOGY mc. 
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msrnucrion SET 
Table 5 lists the instruction set for the CMOS CPU family in alphabetic order according to mnemonic. Table 6 lists the hexadecimal 
codes for each of the instructions that are new to the CMOS family and were not available in the NMOS 6502 device family. Table 
7 lists those instructions that were available on the NMOS family, but have been assigned new addressing modes in the CMOS 
CPU family. 
TABLE 5. INSTRUCTION SET LISTING (ALPHABETIC) 


Mnemwnlc i 


Add Memory to Accumulator with Carry 
"AND" Memory with Accumulator 
Shift Left One Bit (Memory or Accumulator) 
AND 
ASL 


(1)(3) BBR 
(1)(3) ass 
acc 
BCS 
aeo 


(2) 
ADC 
(2) 


Branch on Bit Reset 
Branch on Bit Set 
Branch on Carry Clear 
Branch on Carry Set 
Branch on Result Zero 
(2) 
BIT 
Test Bits in Memory with Accumulator 
BMI 
Branch on Result Minus 
BNE 
Branch on Result not Zero 
BPL 
Branch on Result Plus 
(1) 
BRA 
Branch Always 
BRK 
Force Break 
Bvc 
Branch on Overflow Clear 
Bvs 
Branch on Overflow Set 


CLC 
Clear Carry Flag 
CLI) 
Clear Decimal Mode 
CLI 
Clear Interrupt Disable Bit 
CLV 
Clear Overflow Flag 
(2) 
CMP 
Compare Memory and Accumulator 
cPx 
Compare Memory and Index X 
CPY 
Compare Memory and Index Y 


(2) 
osc 
oex 
DEY 


Decrement Memory by One 
Decrement Index X by One 
Decrement Index Y by One 


(2) 
EOR 
“Exclusive-OR“ Memory with Accumulator 


(2) 
INC 
Increment Memory by One 
INX 
Increment Index X by One 
INY 
Increment Index Y by One 


(2) 
JMP 
JSR 
Jump to New Location 
Jump to New Location Saving Return Address 


(2) 
LDA 
LDX 
LDY 
LSR 


Load Accumulator with Memory 
Load Index X with Memory 
Load Index Y with Memory 
Shift One Bit Right (Memory or Accumulator) 


Notes; 
1. CMOS instruction not available on NMOS Family. 


NOP 


(2) 
ORA 


PHA 
PHP 
(1) 
PHX 
(1) 
PHY 
PLA 
PLP 
(1) 
PLX 
(1) 
PLY 


(1)(3l RMB 
ROL 
ROR 
RTI 
RTS 


(2) 
sec 
sec 
seo 
SEI 
(1)(a) sme 
(2) 
STA 
srx 
STY 
(1) 
srz 


TAX 
TAY 
(1) 
TRB 
(1) 
TSB 
TSX 
TXA 
1xs 
'l'YA 


Funcon 


No Operation 


"OR" Memory with Accumulator 


Push Accumulator on Stack 
Push Processor Status on Stack 
Push X Register on Stack 
Push Y Register on Stack 
Pull Accumulator from Stack 
Pull Processor Status from Stack 
Pull X Register from Stack 
Pull Y Register from Stack 


Reset Memory Bit 
Rotate One Bit Left (Memory or Accumulator) 
Rotate One Bit Right (Memory or Accumulator) 
Return from Interrupt 
Return from Subroutine 


Subtract Memory from Accumulator with Borrow 
Set Carry Flag 
Set Decimal Mode 
Set Interrupt Disable Status 
Set Memory Bit 
Store Accumulator in Memory 
Store Index X in Memory 
Store Index Y in Memory 
Store Zero 


Transfer Accumulator to Index X 
Transfer Accumulator to Index Y 
Test and Reset Bits 
Test and Set Bits 
Transfer Stack Pointer to Index X 
Transfer Index X to Accumulator 
Transfer Index X to Stack Register 
Transfer Index Y to Accumulator 


2. Previous NMOS instruction with additional addressing mode(s) added to the CMOS family. 
3. 65002 instruction not available on VL65NC02. 
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Hex 
Descrlptlon 


80 
3A 
1A 
DA 
5A 
FA 
7A 
9C 
9E 
64 
74 
1C 
14 
0C 
O4 
as 
OF-7F(1) 
8F-FF(1) 
07-77(1) 
87-F7(1 ) 


Note: 


BRA 
DEC 
INC 
PHX 
PHY 
PLX 
PLY 
STZ 
STZ 
STZ 
STZ 
TRB 
TRB 
TSB 
TSB 
BIT 
BBR 
BBS 


Branch Relative Always (Relative) 
Decrement Accumulator (Accum) 
Increment Accumulator (Accum) 
Push X on Stack (Implied) 
Push Y on Stack (Implied) 
Pull X from Stack (Implied) 
Pull Y from Stack (Implied) 
Store Zero (Absolute) 
Store Zero (ABS, X) 
Store Zero (ZP) 
Store Zero (ZP, X) 
Test and Reset Memory Bits with Accumulator (Absolute) 
Test and Reset Memory Bits with Accumulator (ZP) 
Test and Set Memory Bits with Accumulator (Absolute) 
Test and Set Memory Bits with Accumulator (ZP) 
Test Immediate with Accumulator (IMM) 
Branch on Bit Reset (Bit Manipulation, ZP) 
Branch on Bit Set (Bit Manipulation, ZP) 
RMB 
Reset Memory Bit (Bit Manipulation, ZP) 
SMB 
Set Memory Bit (Bit Manipulation,ZP) 


1. 
Most significant digit change only. Instruction not available on 65C02. 


TABLE 7. HEXADECIMAL CODES 
(INSTRUCTIONS WITH NEW CMOS ADDRESSING MODES) 


Hex 
Descrlptlon 


72 
32 
3C 
34 
D2 
52 
7C 
B2 
12 
F2 
92 



ADC 
AND 
BIT 
BIT 
CMP 
EOR 
JMP 
LDA 
ORA 
SBC 
STA 


Add Memory to Accumulator with Carry [(ZP)] 
AND Memory with Accumulator [(ZP)] 
Test Memory Bits with Accumulator [ABS, X] 
Test Memory Bits with Accumulator [ZP, X] 
Compare Memory and Accumulator [(ZP)] 
Exclusive-OR Memory with Accumulator [(ZP)] 
Jump (New addressing mode) [(|ND),X] 
Load Accumulator with Memory [(ZP)] 
OR Memory with Accumulator [(ZP)] 
Subtract Memory from Accumulator with Borrow [(ZP)] 
Store Accumulator in Memory [(ZP)] 
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TABLE 6. HEXADECIMAL CODES (NEW CMOS FAMILY INSTRUCTIONS) 


VLSI TECHNOLOGY, INC. 


LSD 
O 
1 
2 
3 
4 
5 
6 


-I " 
77 


l 
BRK 
ORA 
TSB 
ORA 
I 
ASL 
zs 
ZP 
zs 
Implied (mo, x) 
17 
26 
2523 
25 


" 
i 
7 
S7 
7 
7 
7 
I 
,7 
7 
set. 
I 
ORA 
ORA 
TRB 
ORA 
I 
ASL 
Relative‘*(IND),Y 
(mo) 
ZP 
ZP,X 
ZP,X 


T Jsn I AI~o 
BIT 
Anok ROL 


7 
7 
7 
' 
7 
7 
BMI 
Il 
AND 
BIT 
AND 
ROL 
ReIative,(lND),Y 
ZP,X 
ZP,X 
ZP,X 
22"_2s' 
24 
24126 


RTI 
eon 
, 
I eon 
~ 
LSR 
ZP 
zs 
Implied (mo, x) 


7 
_ 
1 
' 
— 
1% 
7 
i 
7‘:-7. 
- 
S 477* 
7* 
77 
1626 
,23 
2s 
svc 
EOR 
I 
EOR 
, 
LSR 


22". 


Relative (lND),Y 
2 
2" 
2 
5'1 


1 
2 
61' 


BVS 
‘ 
ADC 
ADC 
(IND) 
2 
51' 


BRA 
STA 
Relative (IND, X) 
2 
3' 
2 
6 


BCC 
1 
STA 
Relative. (IND), Y 
I22" 
2s 


STA 
(mo) 
2 
s 


LDY 
LDA 
IMM 
(IND, X) 
I22 
26 


LDX 
IMM 
2 
2 
F 
77 
'77 
scs IILoA 
Relative (mo). Y 
2 
201 
2 
50 


LDA 
(IND) 
2 
5 


CPY 
CMP 
IMM 
I (IND, X) 
2 
2 
2 
6 
I- 
7 
771.7 
7 
~ 
BNE 
CMP 
Relative (lND),Y 
2 2" 
2 
5' 


CMP 
(IND) 
2 
5 
7 
7 
_ 
%- 
— 
~ 
H 
- 
— 
,_— 7”” 
—__ 
7 
r—7 
.1-tm 
CPX 
‘ 
SBC 
‘ 
INC 
SMB6 
ZP 
l 
ZP 
, 
ZP 
ZP 
CPX 
] 
ssc 
IMM ((mo,x) 
2 
2 
‘ 2 
s1 


I sec I "sac 
‘Relative (IND), Y 


l 
fzooj 
sec 
(mo) 
2 
51 


nrs 
I 
Aoc 
srz 
ADC 
( son 
Implied‘ (IND, X) 
ZP 
ZP 
‘ 
ZP 
L 
1 
s 
~ 
2 
3 


lReIative (lND),Y 
1 
\ ZP,X 
I ZP,X 
2 
5' 
2 
4 
2 
6 


2 
31 
2 
s 


STZ 
Aoc 
nos 
ZP,X 
ZP,X 
‘ ZP,X 
2 
4 
2 41* 
2 
s 
77 
7 
777, 
7 
STY 
STA 
I 
STX 
ZP 
ZP 
‘ 
ZP 


,1 
2 
3 
2 
3 
I 
2 
3 
7 
77¢ 
— 
7 
7 
. 
STY 
STA 
I 
STX 


2 
(ZP,X 
ZP,X 
ZP,Y 
4 
, 
2 
4 
2 
4 
I 
A 
LDY 
LDA 
1 
LDX 
ZP 
ZP 
ZP 
2 
3 
“ 
2 
3 
2 
3 


l 
7' 
Ti 
7 
IVY’ 
T’ 
T I .7 
' 
7 


, 
LDY 
LDA 
LDX 
ZP,X 
ZP,X 
ZP,Y 


‘ 
2 
4 
2 
4 
2 
4 


7 
i 
7_j'_ 
_ 
_r* 
_ 
_ 
if 


7 
7,1 
___.T__ 
_ 
_r_ 
Z 
CMP 
* 
DEC 
ZP,X 
ZP,X 
i24;26 


23, 


7 


nmso 
-21> 
2 
s 


RMB1 


RMB3 
ZP 
2 
5 


RMB4 
ZP 
2 
5 


RMB5 
ZP 
2 
5 


RMB6 
ZP 
2 
5 


RMB7 
ZP 
2 
SI 


SMB0 
ZP 
2 
5 


CPY 
‘ 
ICMP 
DEC 
SMB4 


I 
ZP 
ZP 
ZP 
ZP 


I 
2 
3 
‘I 
2 
3 
l 
2 
5 
2 
5 


231’ 
25 
25 
~——I—-I 
J-_ 
SBC 
I 
INC 
ZP, X 
ZP, X 
2 
41' 


4' 
' 
7 
7 
77 
I 
7 
T 
77 


SMB7 
ZP 
26 
25 


TABLE 8. INSTRUCTION SET OPCODE MATRIX 
The following matrix shows the 210 op codes associated with the VL65NC02 microprocessor. The matrix identifies the hexadeci 
mal code, the addressing mode, and the number of machine cycles associated with each op code. 


8 
9 
A 
B 


PHP 
Implied 


1 
3 


ORA 
ASL 
IMM 
Accum 
2 
2 
1 
2 


CLC 
Implied 


I 
INC 
ORA 
ABS, Y 
Accum 


SEC 
Implied 


1 
2 


AND 


‘ ABS, Y 


I 3 
4- 


DEC 
Accum 


PHA 
Implied 


1 
3 


I 
77 
7* 
7 
IEOR 
IIMM 
.22 
l 
7 


LSR 
Accum 


1 
2 


CLI 
Implied 


1 
2 


C 


VL65NC02 


D 
E 


TSB 
ABS 
3 
6 


ORA 
ABS 
3 
4 


ASL 


~ 
ABS 


I 
3 
6 


TRB 
ORA 
ABS 
ABS. 


g7 


1 
ASL 
ABS, X 


AND 
BIT 
ABS, X 
ABS, X 
40 
4. 


~ 
ROL 
ABS. x 


zp 
" 
x 
, 
ZP 
22")2s'2s 
2s 
24 
26 
2s12‘34'12 
3634-3735" 


RMB2 
PLP 
‘Auo 
ROL 
BIT 
AND 
, 
ROL 
ssnz 
ABS 
(|~o.x) 
ZP 
ZP 
I 
zs 
zs 
Implied 
IMM 
Accum 
ABS 
ABS 
ABS 
ZP 
J3s_J2s 
23 
23,25 
25142212 
34 
34l3s3s" 


7 
7 
~ 
I 


I 
F 
JMP 
, 
ABS 
I 
EOR 
ABS 
33l34 


LSR 
ABS 


I 3 
s 


7 ' 
77 
L7 
eon 
PHY 
‘ 
sos 
(ABS,Y 
Implied 
I 
~ ABS,X 


I 
PLA 
Implied 


1 
4 


SEI 
Implied 


1 
2 


DEY 
Implied 


34'13 
A 
i34' 


n 
_ 
7 
LSR 
ABS. X 
3 
7 


, ADC 
ROR 
JMP 
Aoc 
IMM 
Accum 
I 
(ABS) 
ABS 
‘2 
21 
1 
2 
3 
6 
341 


wf 
7 
ROR 
ABS 
3 
6 


I 
ADC 
PLY 
JMP 
ADC 
ABS. Y 
Implied 
ABS, X 
ABS. X 


BIT 
TXA 
IMM 
Implied 
122212 


TYA 
Implied 


1 
2 


STA 
‘ 
TXS 
ABS,Y 
Implied 
l 
3 
5 
1 
2 


g7 


TAY 
Implied 


1 
2 


I 
LDA 
TAX 


1 
IMM 
Implied 
2 
2 
, 
1 
2 
7 
7, 
77 
. 
L 
.l777_I7 


34'114- 
36 
34'1 


\, 
7 
7 
son 
ABS,X 


‘ 
3 
7 


STY 
ABS 
3 
4 


STZ 
ABS 
3 
4 


LDY 
ABS 
3 
4 


STA 
ABS 
3 
4 


STA 
ABS, X 
3 
5 


LDA 
ABS 
34-, 


‘I srx 
ABS 
3 
4 


STZ 
ABS. X 
3 
5 


LDX 


I 
ABS 
3 
4 


CLV 
Implied 


1 
2 


LDA 
I 
TSX 
LDY 
[ 
I 
ABS. Y 
Implied 
ABS. X 
ABS, X 
3 
4' 
1 
2 
\ 
3 4'[ 
3 
4' 


J 
'*.1 
7 
7&7 
7 
T 
7777 


l 
7 
LDX 


I ABS, Y 
134' 


INY 
Implied 


1 
2 


CMP 
DEX 
CPY 
CMP 


I 
IMM 
Ilmplied 
y ABS 
I 
ABS 


CLD 
Implied 


1 
2 


l22‘12‘ 
‘34 
34 


T 


DEC 
ABS 
3 
6 


Ass. Y 
Implied 
\ Ass. X 


INX 
Implied 


1 
2 


34' 
13 
34' 


CMP 
pux 
K 
T 
I 
CMPIIT DEC 
ABS. X 
3 
7 


SBC 
NOP 
I 
CPX 
SBC 


~ 
IMM 
Implied 
lABS* 
ABS 


SED 
Implied 


1 
2 


221’ 
12 
(34i34‘I’I 
L 
7 
7-I: 
I. 
7 
— 
L 


*7 
7 
INC 
ABS 
3 
6 
ssc 
PLX 
ssc 
ABS,Y 
Implied 
ABS,xl 
3 
4-1 
1 
4 
J 
3 
4-1 


INC 
AB$.X 


I 
3 
7 


F 


BBRO 
ZP 
3 
SIG 


BBR1 


BBR3 
ZP 
5.. 


BBR4 
ZP 
3 
5.0 


BBR5 
ZP 
3 
5" 


BBR6 
ZP 
3 
5.. 


BBR7 
ZP 
3 
5.. 


BBSO 
ZP 
3 
5.. 


BBS1 
ZP 
3 
SID 


BBS2 
ZP 
3 
5.. 


BBS3 
ZP 
3 
SIC 


BBS4 
ZP 
3 
500 


BBS5 
ZP 
3 
SCI 


BBS6 
ZP 
3 
SIC 


BBS7 
ZP 
3 
5.. 


O 
1 
2 
3 
4 
5 
6 
7 
8 
9 
A 
B 
C 
D 
E 
F 


1 
7 
—Instruct|on Bytes; Machine Cycles 
Add 2 to N if branch occurs to different page 
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1Add 1 to N if in decimal mode. 
BRK 
—OP Code 
‘Add 1 to N if page boundary is crossed. 
_ New opoode 
0 
Implied 
—Address|ng Mode 
_ 
“Add 1 to N if branch occurs to same page; 


Note All of the op codes in column 7 and column F are interpreted as a NOP in the 65NC02. 
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CRYSTAL/CLOCK CONSIDERATIONS 
Figure 1 shows a time base generation scheme for 4 MHz operation of the VL65NC02 that has been tested and proven reliable for 
normal environments. As with any clock oscillator circuit, stray capacitance due to board layout can cause unpredictable results 
requiring "fine tuning‘ of the circuit. Figure 2 shows a possible external clock scheme for standby mode. Table 9 identifies nominal 
crystal parameters for five crystal frequencies. 


Frequency (MHz) 


Parameter 
E 
0 0 
Unlis 


30 50 
20 40 


OI! 


0900) 


9 Qvs. 
,0’) 
-345‘. 
_O'J 


31.0 


0 
5 
0025 
002 
00 
002 
001002 
pF 


740K 
730K 
720K 
720K 
720K 


Note: AT-cut crystal parameters only. Others may be used. 


FIGURE 1. TIME BASE GENERATOR 


1.5 
3.0 
N 
7404 
>. 
>. 
>. 37 court) 
VLGSNCO2 
U 
o2(ouT) 39 
c2 


XTAL‘ 
15 


Note: CTS Knights MP Series or equivalent. 


FIGURE 2. STANDBY MODE 


>4 
. 
-. 
®0(lN) 
STOP 
3 
Q 
SYNC 
1D 
L=STANDBY 
H=ACT|VE 
“H074 
CPU 


TIME 
_ 
c2(ouT>-> 
BASE 
"(NR 
Q 


+5V 


STOPPING THE CLOCK-STANDBY MODE 


Caution must be exercised when configuring the VL65NC02 in the standby mode (i.e., GO (IN) clock stopped). The input clock 
can be held in the high state indefinitely; however, if the input clock is held in the low state longer than five us, infernal register 
and data status can be lost. Figure 2 shows a circuit that stops the Q50 (IN) clock in the high state during standby mode. 


OQII 


w VLSI TECHNOLOGY, INC. 


FIGURE 3. TIMING DIAGRAM 


IR 
IF 
O0 (IN) 


tSK2 


4-1 tSK1 
IR 
ICH 
O1 (OUT) 
- 
tol- 
I 


92 (OUT) 
477 
[QYC 


I 
mos, IRWS, tSYS 


A0-A15, s/-w 
ii 
<7 


oo-o7 
(ss/to) 


D0-D7 
.,.,. 
(wane) 
{+141 
D'4VII‘44W 
4+2"$44'414:4 
A 


RDY ACTIVE 
RDY, —lRQ 
—NMl,-RES 
U 
U 
Q 
-IRQ -NMI -RES ACTIVE 


{SOS 


-SO 
4 


Note: All timing is referenced from a high level of 2.4 volts and a low level of 0.5 volts. 


936 


IF 


VL65NC02 


' 
IHA, 
READ R/-W : HIGH 
IHRW 
1- wmrw/-w=Low> I 


tHW 


I +'¢'+'0' 
1 
i»~t»:»:+:» 


IIS 


INM I 


IRDS 


tHR 


4"¢"4>"+"¢"+"'+"¢"'¢"'¢"4*+'+"¢"+'¢'+*'¢'¢'¢'¢'¢"¢'6 
4"¢"'+"'¢'¢"'¢‘= 
*4!i!41'4!4213+Z024!0!»202434!+!¢!¢!¢!4!¢!o!¢!>249I!II 201010101010! 


in4'3bio‘. 


® VLSI TECHNOLOGY, n\1c. 
VL65NC02 


AC CHARACTERISTICS: TA = o<>c to +1o<>c, vcc = s v is"/. 


CLOCK TIMING 


tCYC 


tCL 


tCH 


tSK2 


tSK1 


tR, tF 


Symbol 
Parameter 


Y 
. 


1 MHz 


Q '3 \.w 
Z9. Q /\ -A 
Z9.Q /\ 
\I 
(J1 @ 
§ 
-A \.w 
G2 C cle Time 
1000 
Not 
333 
2 
No 


G2 Low Pulse Width 


G2 High Pulse Width 


GO to G2 Low Skew 


G2 LOW to Q1 High Skew 


Clock RIS8 and Fall Times 


'A N 
co C)o 
o 
-to toro Qo 
ro01oo 


o 


I roo 


o 


READ/WHITE TIMING 


Symbol 


tRWS 


tHRW 


tADS 


tHA 


tACC 


tDSU 


tHR 


tMDS 


tHW 


a-L U1 


YO U1- @ 
@@@@Ii'iiI@ 
111$ 
III 
IEIIIE 
IEIEI 
IIEI 
Kill 
IE 


Parameter 


R/-WSetup Time 


R/-W Hold Tlme 


Address Setup Time 


Address Hold TllTl8 


Read Access Time 


-‘\:ow 001 
Read Data Setup Tlme 


Read Data Hold Time 


(J 
_L 


@ @ 
-1. -5 @ 


-1. @ 


Write Data Delay Time 


Write Data Hold TllT‘l8 


CONTROL SIGNAL TIMING 


Symbol 


tSYS 


tRDS 


tSOS 


tlS 


tNMl 


Notes: 


1 MHZ 


U1 


l\)U1 
I 
U1 


Parameter 


SYNC Delay 


RDY Setup Tlme 


-SO Setup Time 


-IRQ -RES Setup Tlme 


-NMI Setup Time 
III 
IHIEIEI 
E111 


Cnlts 


ns 


ns 


ns 


ns 


ns 


ns 


Unlts 


ns 


ns 


ns 


ns 


ns 


ns 


ns 


ns 


ns 


Unlts 


ns 


ns 


ns 


ns 


ns 


1. VL65NC02 minimumyoperating frequency is limited by Q2 low pulse width. The processor can be stopped with G2 held high. 
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ABSOLUTE MAXIMUM RATINGS 
Ambient Operating Temperature: 
Stresses above those listed under 
operational sections of this specification 
- Commercial 
0°C to +70°C 
"Absolute Maximum Ratings" may cause 
is not implied and exposure to absolute 


— Industrial 
-40°C to +85°C 
permanent damage to the device. These 
maximum rating conditions for extended 
Storage Temperature 
_65,C to +1 50°C 
are stress ratings only. Functional 
periods may affect device reliability. 
operation of this device at these or other 
Supply V0|l896 l0 
conditions above those indicated in the 
Ground Potential 
-0.3 to +7.0 V 


Applied Output 
Voltage 
-0.3 to VCC + 0.3 V 


Applied input 
Voltage 
-0.3 to VCC + 0.3 V 


DC CHARACTERISTICS: TA = o<>c to +1000, vcc = +5.0 v 1 5% (Notes 1, 2, 3) 
$v""><=' 
E@E 
T°==*°°"d'"°"* 
W. 
- 
l_ 
.,,L 
$- 
E- 
M Leakage 
Hi 
.,,N , 0 V .0M, V 
llN 
-NMI, -IRQ, RDY, 
A 
VCC = 0 V 


|-rs‘ 
Three-State (Off-State) Input Current 
“A 
VIN = 0.4 V to +2.4 V 
D7 - D0 
VCC = +5.25 V 


VQH 
Output High Voltage 
2_4 
V 
VCC = +4.75 V 
SYNC, D7-D0, A15-A0, R/-W, Q51, Q2 
ILOAD - -100 pA 


VOL 
Output Low Voltage 
+0.4 
V 
VCC =- +4.75 V 
SYNC, D7-DO, A15-A0, R/-W, C1, Q2 
ILOAD - 1.6 uA 


Active (5) 
mA/MHz 
we 
Supplycurrent 
Kilt 
Active <6) iijl 
I-11 
RDY - ° V 


. 
NMI,-lRQ,—SO, RDY 
7 
F 
Cm 
lnputcapacitance 
iii vCC,+.,_.,v, 
</>°<'~> Iii vi~=<>v. 
6'0 
——l 
’TZ1'Z"§1is 
°°“T 
3-K 


Notes: 
(1) All units are direct current (DC). 
(2) A negative sign indicates outward current flow, positive indicates inward flow. 
(3) -IRQ and -NMI require an external pull-up resistor. 
(4) Typical values are shown for VCC = +5.0 V and TA = +25°C. 
(5) Typical value for power estimation only; dependent on frequency of operation. 
(6) Maxim um value for power consumption; independent of frequency of operation. 
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® VLSI TECHNOLOGY, INC. 
VL6522 - VL65C22 - VL65C22V 


FEATURES 
- Low power consuming CMOS 
parallel interface/timer 
-VL65C22 has active pull-ups on 
Pon"B' 
-VL65C22V has resistive pull-ups 
on Port "B" 


- Low cost HMOS parallel interfacel 
timer (VL6522) 


- Two 8-bit bidirectional l/O ports 


- Two 16-bit timer/counters 


- Serial bidirectional peripheral I/O port 


- Programmable Data Direction 
Registers 


PARALLEL INTERFACE/TIMER 


DESCRIPTION 
The VL6522/VL65C22/VL65C22V are 
flexible I/O devices for use with the 
65XX family of processors. The 
VL65C22/VL65C22V are CMOS 
implementations of the VL6522 device. 
All include functions for programmed 
control of up to two peripheral devices 
(Ports A and B). Two program-con- 
trolled 8-bit bidirectional peripheral I/O 
ports allow direct interfacing between 
the microprocessor and selected 
peripheral devices. Two programmable 
Data Direction Registers (A and B) 
allow selection of data direction (input 
versus output) on an individual line-by- 


line basis. Also provided are two pro- 
grammable 16-bit counter/timers with 
latches. 
Timer 1 may be operated in a 
one-shot interrupt mode with interrupts 
on each count-to-zero, or in a free- 
running mode with a series of evenly 
spaced interrupts. Timer 2 functions 
both as an interval and pulse counter. 
Serial data transfers are provided by a 
shift register. Application versatility is 
further increased by various control 
registers, including an interrupt flag 
register, an interrupt enable register, 
and two function control registers. 


PIN DIAGRAM 
BLOCK DIAGRAM 


GND 
PAO 
PA1 
PA2 
PA3 
PA4 
PA5 
PA6 
PA7 
PBO 
PB1 
PB2 
PB3 
PB4 
PB5 
PB6 
PB7 
CB1 
CB2 
VCC 


-IRQ 
PORT A 
VI-6522 
'NTEmU"T 
REGISTERS 
VL65C22 
°°“"‘°‘ 
i~Pu1 


1234567e9 
10 
11 
12 
13 
14 
15 
16 
17 
1e 
19 
20 


CA1 
CA2 
RSO 
RS1 
RS2 
RS3 


D1 
D2 
D3 
D4 
D5 
D6 
D7 
Q2 
CS1 
-CS2 
R/-W 
-IRQ 


DATA 
DATA 
aus 0 
eus 
eurrsn 
FUNCTION 
comnot 
PERIPHE 
PCR 
AUXILIARY 


TTMER1 
Efw 
LATCH 
LATCH 
(nu-1) 
I 
(I'1L L) 
05* 
Beam?“ rsaairrea 
I 
CHIP 
(T1CH) 
(r1c L) 
-CS2 
ACCESS 
R50 
CONTROL 
TIMER2 
R51 
LATCH 
RS2 
SE21“. 
R53 
_ 
COUNTER courrren 
rm H) ' (mu 


(om 0 
(SA: 0 "°““ 


(pom) 


cm 
"ffI‘_ 
<=~= 
PORT a 


VL65C22V 
F5??? 
L?-*3“-"5-*’ 
-Era“-ig 
ourvur 
eu FER 


ER) 
151171311? 


(ACR) 
HAN DSHAKE 
-RES 
corrmot 
D0 
s 
SHIFT REG. 
CB1 


PORT B 
REGISTERS 


INPUT LATCH 
ORB) 
5u?=Fr_ 
BUFFER 
(one) 
0 
(PB) 0 "°‘"° 


DATA DIR 
(DDR8) 


ORDER INFORMATION 
Part 
Clock 
Number 
Technology 
Frequen 


VL6522-01 PC 
HMOS 
VL6522-01OC 
HMOS 
VL6522-02PC 
|-|M0s 
VL65C22-02PC 
CMQS 
VL65C22V-02PC 
CMQS 
ZMHZ 
VL6522-0200 
HMOS 
VL65C22-0200 
CMOS 
VL65C22V-020 
CMOS 
VL65C22-04PC 
CMOS 
VL65C22V-04PC 
CMQ$ 
vi.esc22-0400 
CMOS 
4 MHZ 
VL65C22V-040 
CMOS 
Note: Operating temperature range is 0°C 


°Y 
Package 
Plastic DIP 
Plastic Leaded Chi Carrier PLCC 
Plastic DIP 
Plastic DIP 
Plastic DIP 
Plastic Leaded Chip Carrier (PLCC) 
Plastic Leaded Chip Carrier (PLCC) 
Plastic Leaded Chi Carrier PLCC 
Plastic DIP 
Plastic DIP 
Plastic Leaded Chip Carrier (PLCC) 
Plastic Leaded Chip Carrier (PLCC) 
to +70°C 
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PIN DIAGRAM 


VL6522 
VL65C22 
VL65C22V 


PA3 
PA1 
GND 
CA2 
RS1 
PA4 
PA2 
PAO 
CA1 
RSO 
RS2 
I I I 
214443424140 
PA5 
7 
39RS3 
PA6 
a 
. 
38N.C. 
PA7 
e 
37—RES 
PBO I 
10 
asoo 
N.C. I 
11 
as I 01 
PB1 I12 
a4 I 02 
PB2 I 
13 
33N.C. 
PB3 I 
14 
s2 I pa 
PB4 I 
15 
31 I 04 
PB5 I 
16 
so I os 
PB6 I 
11 
29 I 
D6 
1819202122232425262728 
I I I I I I I I I I I 


PB7 
CB2 
N.C. 
R/-W 
CS1 
D7 
CB1 
VCC 
—IRO -CS2 
CLK 


U5- 
0|- 
A- 
(0- 


— I 
_ 
- 


FIGURE 1. MICROPROCESSOR AND PERIPHERAL INTERFACE 


poor ~ 
w 
PAO-PA7 


Q2 
CA1 


MICROPROCESSOR 
R/—W 
VL6522 
CA2 
PERIPHERAL 
eus INTERFACE 
cs, _CS2 
vI£L6%%C2?v 
INTERFACE 
' 
A 
CB1 
, 
RSO-RS3 
CB2 
-RES 
-mo 
Q 
PBO-PB7 


FUNCTIONAL DIFFERENCES AMONG VL6522, VL65C22, AND VL65C22V 


Functlon 
VL6522 
VL65C22 
VL65C22V ' 


. 
. 
. 
AD 
ddD 
-62 
AD 
ddD'—C2 
Hamster select Lmes 
Are Decoded Durmg ‘Q2 
Orr?ly IIIEICSGZ is :IInAJctive Low 
Ornely ife?CSe2 is :IInAJctive Low 


05 
Must Not Change During Last 
Must Not Change During Last 
Can Change Anytime, But is 
100 ns of -62 
Sampled Only During -62 
100 ns of -02 


Port B (PBO - PB7, 
Has Active (Transistor) 
Has Active (Transistor) 
Has Passive (Resistor, Approx. 
CB1, CB2) 
Internal Pull ups 
6 kohms) Internal Pull-ups 
Internal Pull ups 


PM B (PBO _ PB7 
Each pin represents one Stan- 
Each pin represents two Stan- 
Each pin represents one Stan- 
CB1 CB2) 
’ 
dard TTL load either as an input 
dard TTL loads either as an 
dard TTL load either as an input 
’ 
or as an output 
input or as an output 
or as an output 
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SIGNAL 
DESCRIPTIONS 


Pln 
Slgnal 
Name 


-RES 


Q2 


R/-W 


D0-D7 


CS1, -CS2 


RSO, RS1, RS2, 
RS3 


-IRQ 


PAO - PA7 


PBO - PB7 


CA1. CA2 


CB1. CB2 


VCC 


GND 


Slgnal 
Number 
Descrlptlon 


34 


25 


22 


33-26 


24, 23 


38 -35 


21 


2-9 


10-17 


40,39 


18,19 


20 


1 


AA low reset (-RES) input clears all VL65(C)22(V) internal registers to logic 0 (except T1 
and T2 latches and counters and the Shift Register). This places all peripheral interface 
lines in the input state; disables the timers, shift register, and interrupting from the chip. 


The input clock is the system O2 clock and triggers all data transfers between processor 
bus and the VL65(C)22(V). 


The direction of the data transfers between the VL65(C)22(V) and the system processor 
is controlled by the R/-W line and the CS1 and -CS2 inputs. When R/—W is low, (write 
operation) and the VL65(C)22(V) is selected, data is transferred from the processor bus 
into the selected VL65(C)22(V) register. When R/-W is high, (read) and the chip is 
selected, and data is transferred from the selected VL65(C)22(V) register to the CPU. 


The eight bidirectional data bus lines transfer data between the VL65(C)22(V) and the 
system processor bus. During ready cycles, the contents of the selected VL65(C)22(V) 
register are placed on the data bus lines. During write cycles, these lines are high- 
impedance inputs and data is transferred from the processor bus into the selected 
register. When the VL65(C)22(V) is not selected, the data bus lines are high-impedance. 


The two chip select inputs are normally connected to processor address lines either 
directly or through decoding. The selected VL65(C)22(V) register is accessed when CS1 
is high and -CS2 is low. 


The coding of the four Register Select inputs selects one of the 16 internal registers of 
the VL65(C)22(V), as shown in Table 2. 


The Interrupt Request output goes low whenever an internal interrupt flag is set and the 
corresponding interrupt enable bit is a logic 1. This output is open-drain to allow the 
interrupt request signal to be wire-or'd with other equivalent signals in the system. 


Port A consists of eight lines which can be individually programmed to act as inputs or 
outputs under control of Data Direction Register A. The polarity of output pins is con- 
trolled by an Output Register and input data may be latched into an internal register 
under control of CA1 line. All modes of operation are controlled by the system processor 
through the internal control registers. These lines, as inputs represent one standard 
TTL load in the input mode and will drive one standard TTL load in the output mode. 


Peripheral Data Port B is an 8-line, bidirectional bus, controlled by an Output Register, 
Input Register and Data Direction Register similar to Data Port A. The output signal on 
line PB7 may be controlled by Timer 1 while Timer 2 may be programmed to count 
pulses on PB6 line. VL6522 and VL65C22 Port B lines are also capable of sourcing 3.0 
mA at 1.5 VDC in the output mode. This allows the outputs to directly drive Darlington 
transistor circuits. VL65C22V Port B lines have internal pull-up resistors (3 kn) to VCC. 


Control Lines CA1 and CA2 serve as interrupt inputs or handshake outputs for Periph- 
eral Data Port A. Each line controls an internal Interrupt Flag with a corresponding 
Interrupt Enable bit. CA1 also controls the latching of Input Data on Port A. CA1 is a 
high impedance input, while CA2 represents one standard Tl'L load in the input mode. 
In the output mode, CA2 will drive one standard 'I'I'L load. 


Control lines CB1 and CB2 are interrupt inputs or handshake outputs for Peripheral Data 
Port B. Like Port A, these two lines control an internal Interrupt Flag with a correspond- 
ing Interrupt Enable bit. These lines are also a serial data port under control of the Shift 
Register (SR). Each control llne represents two standard 'I'l'L loads in the input mode 
(one TTL load on the VL65C22V) and can drive two TTL loads in the output mode (one 
TTL load for the VL65C22V). CB1 and CB2 cannot drive Darlington transistor circuits. 


+5 Volts 


Ground 


llj 
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FUNCTIONAL 
DESCRIPTION 
PERIPHERAL DATA PORTS 
(PORT A, PORT B) 
Each Peripheral Data Port operates in 
conjunction with a Data Direction 
Register (DDRA or DDRB). Under 
program control, the Data Direction 
Registers specify which lines within the 
port bus are to be designated as inputs 
or outputs. A Logic 0 in any bit position 
of the register will cause the correspond- 
ing line to serve as an input, while a 
Logic 1 will cause the line to serve as an 
output. 


When a line is programmed as an 
output, it is controlled by a correspond- 
ing bit in the Output Register (ORA or 
ORB). A Logic 1 in the Output Register 
will cause the corresponding output line 
to go high, while a Logic 0 will cause the 
line to go low. Under program control, 
data is written into the Output Register 
bit positions corresponding to the output 
lines which have been programmed as 
outputs. Should data be written into bit 
positions corresponding to lines which 
have been programmed as inputs, the 
output lines will be unaffected. 


When reading a Peripheral Data Port, 
the contents of the corresponding Input 
Register (IRA or IRB) are transferred 
onto the Data Bus. When the input 
latching feature is disabled, Input 
Register A (IRA) will reflect the logic 
levels present on the Port A bus lines. 
However, with input latching enabled 
and the selected active transition on 
CA1 having occurred, Input Register A 
will contain the data present on the Port 
A bus lines at the time of the transition. 
In this case, once Input Register A has 
been read, it will appear transparent, 
reflecting the current state of the Port A 
bus lines until the next CA1 latching 
transition. 


With respect to Input Register B, it 
operates similar to Input Register A 
except that for those Port B bus lines 
which have been programmed as 
outputs, there is a difference. When 
reading Input Register A, the logic level 
on the bus line determines whether a 
Logic1 or0 is sensed. However, when 
reading the Input Register B, the logic 
level stored in Output Register B (ORB) 
is the logic level sensed. For this 
reason, those outputs which have large 
loading effects may cause the reading of 


Input Register A to result in the reading 
of Logic 0 when a 1 was actually 
programmed, and reading a Logic 1 
when a 0 was programmed. However, 
when reading Input Register B, the logic 
level read will be correct, regardless of 
loading on the particular bus line. 


For information on formats and 
operation of the Peripheral Data Port 
registers, refer to Figures 14, 15, 16, 
and 17. It should be noted that the 
input latching modes are controlled by 
the Auxiliary Control Register . 


DATA TRANSFER - HANDSHAKE 
CONTROL 
A powerful feature of the VL65(C)22(V) 
is its ability to provide absolute control 
over data transfers between the 
microprocessor and peripheral devices. 
This control is accomplished by way of 
"handshake" lines. Port A lines (CA1, 
CA2) handshake data transfers on both 
Read and Write operations, while Port B 
lines (CB1, CB2) handshake data on 
Write operations only. 


READ HANDSHAKE CONTROL 
Read Handshaking provides effective 
control of data transfers from a periph- 
eral device to the microprocessor. To 
accomplish the Read Handshake, the 
peripheral device generates a Data 
Ready signal to the VL65(C)22(V) which 
indicates valid data is present on the 
Peripheral Data Port bus. In most 
cases, this Data Ready signal will 
interrupt the microprocessor, which will 
then read the data and generate a Data 
Taken signal. Once the peripheral 
senses the Data Taken signal, new data 
will be placed on the bus. This process 
continues until the data transfer is 
complete. 


Automatic Read Handshaking applies to 
Peripheral Data Port A only. The Data 
Ready signal is transmitted by the 
peripheral device over the CA1 interrupt 
line, while the Data Taken signal is 
generated and transmitted to the 
peripheral device over the CA2 line. 
When the Data Ready signal is re- 
ceived, it sets an internal flag in the 
Interrupt Flag Register (IFR). This flag 
may interrupt the microprocessor or it 
may be polled under program control. 
As an option, the Data Taken signal 
may be either a pulse or a level. In 


either case, it is set low (Logic 0) by the 
microprocessor and is cleared by the 
next Data Ready signal. Refer to 
Figures 2 and 3 for Read Handshake 
timing and operating sequence. 


WRITE HANDSHAKE CONTROL 
The Write Handshake operation is 
similar to Read Handshaking. For Wrlte 
Handshaking, however, the 
VL65(C)22(V) generates the Data 
Ready signal and the peripheral device 
must generate the Data Taken return 
signal. Note that Write Handshaking 
may occur on both Data Ports (A and 
B). For a Write Handshake, CA2 or 
CB2 serve as the Data Ready output 
and can operate in either the Hand- 
shake Mode orthe Pulse Mode. The 
Data Taken signal is received by CA1 
or CB1. The Data Taken signal sets a 
flag in the Interrupt Flag Register and 
clears the Data Ready output signal. 
Note that the selection of Read or Write 
Handshake operating modes (CA1, 
CA2, CB1, and CB2) is accomplished 
by the Peripheral Control Register 
(PCR). 


INTERRUPT OPERATION 
There are three basic operations, 
including: setting the flag within the 
Interrupt Flag Register (IFR), enabling 
the interrupt by way of a corresponding 
bit in the Interrupt Enable Register 
(IER), and signaling the microprocessor 
with an Interrupt Request (IRO). An 
Interrupt Flag can be set by conditions 
Internal to the chip or by inputs to the 
chip from external sources. Normally, 
an Interrupt Flag remains set until the 
interrupt is serviced. To determine the 
source of an interrupt, the micro- 
processor must examine each flag in 
order, from highest to lowest priority. 
This is accomplished by reading the 
contents of the Interrupt Flag Register 
into the microprocessor accumulator, 
shifting the contents either left or right 
and then using conditional branch 
instructions to detect an active interrupt. 
Each Interrupt Flag has a correspond- 
ing Interrupt Enable bit in the Interrupt 
Enable Register. The enable bits are 
controlled by the microprocessor (set or 
reset). If an Interrupt Flag is high (Logic 
1), and the corresponding Interrupt 
Enable bit is high (Logic 1), the Interrupt 
Request (IRO) will go low (Logic 0). 
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FUNCTIONAL 
DESCRIPTION (Cont.) 
IRQ is an open-collector output which 
can be wire-or‘d with other devices 
within the system. 


All Interrupt Flags are contained within 
a single Interrupt Flag Register. Bit 7 of 
this register will be high (Logic 1) 
whenever an Interrupt Flag is set, thus 
allowing convenient polling of several 
devices within a system to determine 
the source of the interrupt. 


The Interrupt Flag Register (IFR) and 
Interrupt Enable Register (IER) format 
and operation is shown in Figures 28 
and 29 respectively. The Interrupt Flag 
Register may be read directly by the 
micrprocessor, and individual flag bits 
may be cleared by Writing a "1" into the 
appropriate bit of the IFR. Bit 7 of the 
IFR indicates the status of the Interrupt 
Request (IRO) output. Bit 7 corre- 
sponds to the following logic function: 
IRO = IFR6 x lER6 + IFRS x IER5 + 
IFR4 x IER4 + IFR3 x IER3 + lFR2 x 
lER2 + IFR1 x IER1 + IFRO x IERO. 
Note X =- LogicAND. + = LogicOR. 


Bit 7 is not a flag. For this reason, bit 7 
is not directly cleared by writing a "1 " 
into its bit position. It can be cleared, 
however, by clearing all the flags within 
the register, or by disabling all active 
interrupts in the next section. 


TIMER OPERATION 
Timer 1 Operation - Interval Timer T1 
consists of two 8-bit latches and a 16-bit 
counter. The latches serve to store 
data which is to be loaded into the 
counter. Once the counter is loaded 
under program control, it decrements at 
a Phase 2 (O2) clock rate. Upon 
reaching zero, an Interrupt Flag is set, 
causing Interrupt Request (IRO) to go 
low (Logic O) if the corresponding 
Interrupt Enable bit is set. Once the 
Timer reaches a count of zero, it will 
either disable any further interrupts 
(provided it has been programmed to do 
so), or it will automatically transfer the 
contents of the latches into the counter 
and proceed to decrement again. The 
counter may be programmed to invert 
the output signal on PB7 each time it 
reaches a count of zero. Additional 
control bits are provided in the Auxiliary 
Control Register (bits 6 and 7) to allow 
selection of Timer 1 operating modes. 
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It should be noted that the microproces- 
sor does not write directly into the low- 
order counter (T1 C-L). Instead, this half 
of the counter is loaded automatically 
from the low-order register when the 
microprocessor writes into the high- 
order register and counter. In fact, it 
may not be necessary to write to the 
low-order register in some applications 
since the timing operation is triggered 
by writing to the high-order register and 
counter. 


Timer 1 One-Shot Mode - Inten/al Timer 
T1 may operate in the One-Shot Mode 
which allows the generation of a single 
Interrupt Flag each time the Timer is 
loaded. The Timer can also be pro- 
grammed to produce a single negative 
pulse on Data Port Line PB7. 


To generate a single interrupt, it is 
required that bits 6 and 7 of the 
Auxiliary Control Register be low (Logic 
0). The low-orderT1 counter (T1C-L) 
or the low-order T1 latch (T1 L-L) must 
then be loaded with the low-order count 
value. Note that a load to T1 C-L is 
effectively a load to T1 L-L. Next, the 
high-order count value must be loaded 
into the high-order T1 counter (T1 C-H), 
at which time the value is simultane- 
ously loaded into high-order T1 latch 
(T1L-H). During this load sequence, the 
contents of T1 L-L is transferred to T1 C- 
L. The counter will start counting down 
on the next O2 clock following the load 
sequence into T1 C-H, and will decre- 
ment at the O2 clock rate. Once the T1 
counter reaches a zero count, the 
Interrupt Flag is set. To generate a 
negative pulse on Data Port line PB7, 
the sequence is identical to the above 
except bit 7 of the Auxiliary Control 
Register must be high (Logic 1). Data 
Port line PB7 will then go low (Logic 0) 
following the load to T1 C-H, and will go 
high (Logic 1) again when the counter 
reaches a zero count. Once set, the T1 
Interrupt Flag is reset by either loading 
T1 C-H, which starts a new count, or by 
reading T1 C-L. 


Timer 1 Free-Run Mode - An important 
advantage within the VL65C22 is the 
ability of the latches associated with the 
T1 counter to provide a continuous 
series of evenly spaced interrupts or a 
square wave on Data Port line PB7. It 
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should also be noted that the continu- 
ous series of interrupts and square 
waves are not affected by variations in 
the microprocessor interrupt response 
tlme. These advantages are all 
produced in the Free-Run Mode.- When 
operating in the Free-Run Mode, the 
Interrupt Flag is set and the signal on 
PB7 is inverted each time the counter 
reaches a count of zero. In the Free- 
Run Mode, however, the counter does 
not continue to decrement after 
reaching a zero count. Instead, the 
counter automatically transfers the 
contents of the latch into the counter 
(16 bits) and then decrements from the 
new count value. As can be seen, it is 
not necessary to reload the timer in 
order to set the Interrupt Flag on the 
next count of zero. When set, the 
Interrupt Flag can be cleared by either 
reading T1 C-L, by writing directly into 
the Interrupt Flg Register (IFR) as will 
be discussed later, or by a load into 
T1 C-H when a new count value is 
deshed. 


Since the interval timers are all refrig- 
gerable, reloading the counter will 
always reinitialize the time-out period. 
Should the microprocessor continue to 
reload the counter before it reaches 
zero, counter time-out can be pre- 
vented. Timer 1 is able to operate in 
this manner provided the microproces- 
sor writes into the high-order counter 
(T1 C-H). By loading the latches only, 
the microprocessor can access the 
timer during each count-down operation 
without affecting the time-out in 
progress. In this way, data loaded Into 
the latches will determine the length of 
the next subsequent time-out period. 
This capability is of value In the Free- 
Run Mode with the output enabled. In 
the Free-Run Mode, the slgnal on Data 
Port line PB7 is inverted and the 
Interrupt Flag is set with each counter 
time-out. When the microprocessor 
responds to the interrupts with new data 
for the latches, it can determine the 
period of the next half-cycle during each 
half-cycle of the output signal on line 
PB7. In this way, complex waveforms 
can be generated. 


Timer 2 Operation - 'Iimer 2 operates In 
the One-Shot Mode only (as an Interval 
timer), or as a pulse counter for 


FUNCTIONAL 
DESCRIPTION (Cont.) 
counting negative pulses on Data Port 
line PB6. A single control bit within the 
Auxiliary Control Register is used to 
select between these two modes. Timer 
2 is made up of a write-only low-order 
latch (T2L-L), a read-only low-order 
counter (T2C-L), and a read/write high- 
order counter (T2C-H). This 16-bit 
counter decrements at a O2 clock rate. 


Timer 2 One-Shot Mode - Operation of 
Timer 2 in the One-Shot Mode is similar 
to Timer 1. That is, for each load T2C-H 
operation, Timer 2 sets the Interrupt 
Flag for each countdown to zero. 
However, after a time-out, the T2 
counters roll over to all 1's (FFF16) and 
continue to decrement. This two's 
complement decrement allows the user 
to determine how long the T2 Interrupt 
Flag has been set. Since the Interrupt 
Flag logic is disabled after the initial 
interrupt set (zero count), further 
interrupts cannot be set by a subse- 
quent count to zero. To enable the 
Interrupt Flag logic, the microprocessor 
must reload T2C-H. The Interrupt Flag 
is cleared by either reading T2C-L or by 
loading T2C-H. 


Timer 2 Pulse Counting Mode-In the 
Pulse Counting Mode, Timer 2 counts a 
predetermined number of negative- 
going pulses on Data Port line PB6. To 
accomplish this, a count number is 
loaded into T2C-H, which clears the 
Interrupt Flag logic and starts the 
counter to decrement each time a 
negative pulse is applied to Data Port 
line PB6. When the T2 counter reaches 
a count of zero, the Interrupt Flag is set 
and the counter continues to decrement 
with each pulse on PB6. To enable the 
Interrupt Flag for subsequent count- 
downs, it is necessary to reload T2C-H. 
The decrement pulse on line PB6 must 
be low (Logic 0) during the leading edge 
of the O2 clock. 


SHIFT REGISTER OPERATION AND 
MODES 
Shift Register Operation - The Shift 
Register performs bidirectional serial 
data transfers on line CB2. These 
transfers are controlled by an internal 
modulo-8 counter. Shift pulses can be 
applied to the CB1 line for controlling 
external devices. Each Shift Register 
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operating mode is controlled by control 
bits within the Auxiliary Control Register. 
Shift Register Input Modes -Shift 
Register Disabled (000) - In the 000 
mode, the Shift Register is disabled from 
all operation. the microprocessor can 
read or write the Shift Register, but 
shifting is disabled and both CB1 and 
CB2 are controlled by bits in the 
Peripheral Control Register (PCR). The 
Shift Register Interrupt Flag is held low 
(disabled). 


Shift In - Counter T2 Control (001) - In 
this mode, the shifting rate is controlled 
by the low order eight bits of counter T2. 
Shift pulses are generated on the CB1 
line to control shifting in external 
devices. The time between transitions 
of the CB1 output clock is determined by 
the O2 clock period and the contents of 
the low-order T2 latch (N). Shifting 
occurs by writing or reading the Shift 
Register. Data is shifted into the low- 
order bit first, and is then shifted into the 
next higher order bit on the negative- 
going edge of each clock pulse. Input 
data should change before the positive- 
going edge of the CB1 clock pulse. This 
data is then shifted into the Shift 
Register during the O2 clock cycle 
following the positive-going edge of the 
CB1 clock pulse. After eight CB1 clock 
pulses, the Shift Register Interrupt Flag 
will set the IRO will go low (Logic 0). 


Shift In - O2 Clock Control (010) - In this 
mode, the shift rate is controlled by the 
Q2 clock frequency. Shift pulses are 
generated on the CB1 line to control 
shifting in external devices. Timer 2 
operates as an independent interval 
timer and has no influence on the Shift 
Register. Shifting occurs by reading or 
writing the Shift Register. Data is shifted 
into the low order bit first, and is then 
shifted into the next higher order bit on 
the trailing edge of the Q2 clock pulse. 
After eight clock pulses, the Shift 
Register Interrupt Flag will be set and 
output clock pulses on the CB1 line will 
stop. 


Shift In - External CB1 Clock Control 
(011) - In this mode, CB1 serves as an 
input to the Shift Register. In this way, 
an external device can load the Shift 
Register at its own pace. The Shift 
Register counter will interrupt the 
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microprocessor after each eight bits 
have been shifted in. The Shift 
Register counter does not stop the 
shifting operation. Its function is simply 
that of a pulse counter. Reading or 
writing the Shift Register resets the 
Interrupt Flag and initializes the counter 
to count another eight pulses. Note that 
data is shifted during the first Q2 clock 
cycle following the positive-going edge 
of the CB1 shift pulse. For this reason, 
data must be held stable during the first 
full cycle following CB1 going high. 


Shift Out - Free Running at T2 Rate 
(100) -This mode is similar to mode 101 
in which the shifting rate is determined 
by T2. However, in mode 100 the Shift 
Register Counter does not stop the 
shifting operation. Since Shift Register 
bit 7 (SR7) is recirculated back into bit 
0, the eight bits loaded into the Shift 
Register will be clocked onto the CR2 
line repetitively. In this mode, the Shift 
Register Counter is disabled and IRQ is 
neverset 


Shift Out - T2 Control (101) - In this 
mode, the shift rate is controlled by T2 
(as in mode 100). However, with each 
read or write of the Shift Register, the 
Shift Register Counter is reset and eight 
bits are shifted onto the CB2 line. At 
the same time, eight shift pulses are 
placed on the CB1 line to control 
shifting in external devices. After the 
eight shift pulses, the shifting is 
disabled, the Interrupt Flag is set, and 
CB2 will remain at the last data level. 


Shift Out - O2 Clock Control (110) - In 
this mode, the shift rate is controlled by 
the system O2 Clock. 


Shift Out - External CB1 Clock Control 
(111) - In this mode, shifting is con- 
trolled by external pulses applied to the 
CB1 line. The Shift Register Counter 
sets the Interrupt Flag for each eight- 
pulse count, but does not disable the 
shifting function. Each time the 
microprocessor reads or writes to the 
Shift Register, the Interrupt Flag is reset 
and the counter is initialized to begin 
counting the next eight pulses on the 
CB1 line. After eight shift pulses, the 
Interrupt Flag is set. The microproces- 
sor can then load the Shift Register with 
the next eight bits of data. 
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TABLE 1. PERIPHERAL INTERFACE CHARACTERISTICS TA = o-c to 1o-c, vcc = s v :I:5% 


Parameter 
Typ 
Symbol 
IR, IF 


tCA2 


tRS1 


tRS2 


IWHS 


tDS 


tRS3 


IRS4 


I21 


IIL 


ISR1 


ISR2 


tSR3 


tlPW 


tICW 


IIPS 


IICS 


tAL 


tPDH 


_Lb 


ise and Fall Time for CA1 CB1 CA2 and CB2 Input Signals 


Delay Time, Clock Negative Transition to CA2 Negative 


Transition (Read Handshake or Pulse Mode) 


Delay Time, Clock Negative Transition to CA2 Positive 


Transition Pulse Mode 


Delay Time, CA1 Active Transition to CA2 Positive Transition 


(Handshake Mode) 


Delay Time Clock Positive Transition to CA2 or CB2 Negative 


Transition (Write Handshake) 


Delay Time Peripheral Data Valid to CB2 Negative Transition 


Delay Time, Clock Positive Transition to CA2 or CB2 Positive 


Transition (Pulse Mode) 


Delay Time, CA1 or CB1 Active Transition to CA2 or CB2 


Positive Transition (Handshake Mode) 


Delay Time Required from CA2 Output to CA1 Active 


Transition (Handshake Mode) 
Set up Time Peiipiieiei Data Valid to CA1 ei CB1 Active 


Transition (Input Latching) 


Shift-Out Delay Time 
Time from O2 Falling Edge to CB2 


DmaOm 


Shift In Set up Time 
Time from CB2 Data In to O2 Rising Edge 


External Shift Clock (CB1) Set up Time Relative to O2 
tCYC 


Piiiee Width PB6 iiipiii PUIS6 
2- 


Pulse Width 
CB1 Input Clock 


Pulse Spacing 
PB6 Input Pulse 
2 x tCYC 


Pulse Spacing 
CB1 Input Pulse 
2 x tCYC 


CA1 
CB1 Set Up Prior to Transition to Arm Latch 


Peripheral Data Hold After CA1 CB1 Transition 


‘Note: This specification is "0' (zero) on the VL65C22V. 
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Unl 


I15 


I15 


I15 


I18 


I15 


I15 


I15 


I1$ 


ns 


I"IS 


RS 


FIS 


ITS 


ITS 


ITS 
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FIGURE 2. TIMING FOR READ HANDSHAKE, PULSE MODE 
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0.8 V 
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FIGURE 3. TIMING FOR READ HANDSHAKE, HANDSHAKE MODE 
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/ 
0.8 V 


I 
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FIGURE 4. TIMING FOR WRITE HANDSHAKE, PULSE MODE 
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FIGURE 5. TIMING FOR WRITE HANDSHAKE, HANDSHAKE MODE 
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FIGURE 6. PERIPHERAL DATA INPUT LATCHING TIMING 
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9!“coo << 


INPUT 
4 3% 
LATCHING 


TRANSITION 


FIGURE 7. TIMING FOR SHIFT OUT WITH INTERNAL OR EXTERNAL SHIFT CLOCKING 


O2 
I 
I 
I 
I 
I 
:I:0.8 V 
I 
I 
I 
I 
I 
I 


CB2 
SH"‘T 
—< 
<>.8v 
DATA (ourpun 


SHIFT CLOCK 
(INPUT on 
OUTPUT) 
DELAY TIME MEASURED FROM 


THE FIRST Q2 AFTER CB1 
FALLING EDGE 
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FIGURE 8. TIMING FOR SHIFT IN WITH INTERNAL OR EXTERNAL SHIFT CLOCKING (VL6522 AND VL65C22) 


cs2 
— 
‘SR2 in 
3”" 
DATA (INPUT) 
- 
— 
A 
ON (DO << 


cs1 
SI-"FT CI-°°K 
‘"4 V//J’ "4 V 
SETUP TIME MEASURED To THE 
(‘NPUT QR 
I393 
I=IRsT Q2 RISING EDGE AFTER 
QUTPUTI 
cs1 RISING EDGE. 


FIGURE 8A. TIMING I=oR SHlFl' IN WITH INTERNAL 0R EXTERNAL SHIFl' CLOCKING (VL65C22V) 


Q2 _ 


1.4 V 
1.4 V 
MUST BE HIGH DURING THE FULL 
CB1 
I 
I 
VL65C22V Q2 HIGH SAMPLE PERIOD. 
SH“ CLOCK 
tSR2 (VL65C22V) —> 
l 
I 


INTERNAL 
SHIFT PULSE 
. 
I 
I 


I 
I 


I 
I 
cs2 
VAUD 
MUST BE VALID DURING THE FULL 
DATA 
A 
VL65C22V INTERNAL SHIFT PULSE PERIOD 


FIGURE 9. EXTERNAL SHIFT CLOCK TIMING 
_ 


CB1 
2.0 V 
2.0 V 
SHIFT CLOCK 
0.8 V 
0.8 V 
INPUT 


IICW 
IICS 


FIGURE 10. PULSE COUNT INPUT TIMING 


2.0 V 
2.0 V 
P55 
0.8 V 
0.8 V 
I 
PULSE CLOCK 
I 
INPUT 


IIPW 
IIP3 


COUNTER 
T2 DECREMENTS 
HERE 
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N 


Reglste 
Number 


O 


1 


¢O@\JG’JO‘I-h(JI\) 


10 


11 


12 


13 


14 


15 


Notes 


VLSI TECHNOLOGY, INC. 
VL6522 - VL65C22 - VL65C22V 


TABLE 2. REGISTER SELECT 
RS Coding 
Register/De 
r 
Register 
Designation 
Wrlte (R/-W=0) 


s 


ORB I IRB 
Output Register B 


ORA I IRA 
Output Register A 


DDRB 
Data Direction Register B 


DDRA 
Data Direction Register A 


T1C 
L 
T1 Low-Order Latches 


T1C 
H 
T1 High Order Counter 


T1L 
L 
T1 Low-Order Latches 


T1L 
H 
T1 HIgh Order Latches 


T2C 
L 
T2 Low-Order Latches 


T2C 
H 
T2 High-Order Counter 


Shiit Register 


Auxiliary Control Register 


Peripheral Control Register 


Interrupt Flag Register 


InterruptEnable Register 


Output Register A 


AC 


PC 


TI 
ORA / IRA 


1. ' - Same as Register 1, except no handshake 


crlptlon 


Read (R/-W=1) 
Input Register B 


Input Register A 


T1 Low-Order Counter 


T2 Low-Order Counter 


Input Register A ' 


2. On the VL65C22V and VL65C22, the Register Select may be decoded only while -CS2 is low. 
TABLE 3. READ TIMING 


Y 


tCYC 


IACR 


ICAR 


IPCR 


ICDR 


tHR 


WlIWIIIH@EH@IIIIH@ 
IIIH@III§IIIEK 
“°°'°“ S°‘"PT""° 
IEIEI!EI-§- 
"°°'°$s “°'° T""° 
KZ1I1_I—— 
‘°°"P'"°"*' Dala $°‘“P“'“° WHE-- 
Daia B“ °°'aY “"'° 
-@-@-@—@ 
IIIZIIZIII 
ata Bus Hold Tlme 
-AO 


TABLE 4. WRITE TIMING 


Symbol 


tCYC 


tC 


tACW 


tCAW 


tWCW 


tCWW 


tDOW 


tHW 


tCPW 


tCMOS 


IE@IEII'EIIlHIII’;IIIIII'I‘B 
IEI@II 
1 


Parameter 


Cycle Time 


2 Pulse WIdth 


Address Setup Time 


Address Hold Time 
-W Setup Tlme 


R/--W Hold Tlme 


Data Bus Setup Tim 


old Time 


Peripheral Data Delay Time 


Peripheral Data Delay Time 
to CMOS Levels 


8 


ata Bus H 


Note: 
tRlSE, tFALL = 10 to 30 ns. 
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VL6522-O1 
VL6522-02 
VL65C22(V)-02 
L65C22(V)-04 


S mbol 
Parameter 
Units 


I45 
ns 


HS 


RS 


I18 


I18 


Unite 


I18 
8 
8 
8 
8 
8 
8 


E8 


‘8 


w VLSI TECHNOLOGY, INC. 
VL6522 - VL65C22 - VL65C22V 


FIGURE 11. READ TIMING 


IACR 
tCYC 


IR 


Q2 CLOCK 
é 


\ — 
EIZRLPHERAL 
\\\< 
— 


IHR 


BUS 


FIGURE 12 
WRITE TIMING 


tCYC 


IC 


IDCW 


R/--W 


ICMOS 


tCPW 
VCC 
g;¢;P~ER» 
< 
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FIGURE 13. REGISTER O, ORB/IRB 
FIGURE 14. REGISTER 1, ORAIIRA 
ill 
’ 
6 5 ‘ * * ' 
P86‘ 


I 
PB1; 


P821 


r 
*-PBS 


PB4 


-I 
— 
PB6 


1 
W 
,, 


PIN 
DATA DIRECTION 
SELECTION 
I--._i. 


A Ps7__ 


I 
OUTPUT REGISTER 
P83’ “Bu 
INPUT REGIsTER 
I 
..B.. (IRB) 
. “SI “A” (IRA) 


WRITE 


DDRe - "1" (GUTPUTT 
(ORB) 


O 
I 
I 


READ 


MPU WRITES OUTPUT LEVEL 
MPU READS OUTPUT REGISTER 
BIT IN ORB. PIN LEVEL HAS NO 
AFFECT 


I 


I 
1 


PAD“ 


PA1 


PA2 


PA3 


PA4 


__ “A" (ORA) OR 
INPUT REGISTER 


OUTPUT REGISTER 


J 
-PA6 
.........._-PA7_] 
|‘_pIT'_I"'___ 
'__— 
DATA DIRECTION 
WRITE 
SELECTION 
-_ 
__ 
L._J_-_ 


READ 


DDRA 
"1 " (OUTPUT) 
MPU WRITES OUTPUT LEVEL 
(INPUT LATCHING DISABLED) 
I 
(om) 


DDRB - "0" (INPUT) 
(INPUT LATCHING DISABLED) 


4i 
MPU WRITES INTO ORB. BUT 
NO EFFECT ON PIN LEVEL, 
UNTIL DDRB CHANGED 
DDRB - "o" (INPUT) 
(INPUT LATCHING ENABLED) 


i 
I i 
__I 
MPU READS INPUT LEVEL ON PB 
PIN 


MPU READS IRB BIT. WHICH IS THE 
LEVEL OF THE PB PIN AT THE TIME 
OF THE LAST CB1 ACTIVE 
TRANSITION 


j 
J 
— 
L 
DDRA = --1" (OUTPUT) 
(INPUT LATCHING ENABLED) 
I 


2 
A 
.__I~_._. 
_ 
E 
8* 
-- 
| (INPUT LATCHING ENABLED) 
l 


FIGURE 15. REGISTER 2, DDRB 
laanaana 


I 
I 
I 
L—-—iPso 
"I 


PB1 


PB2 


I 
I 
Pea 


(HIGH IMPEDANCE) 
"1" 
ASSOCIATED PB PIN IS AN OUTPUT 
WHOSE LEVEL IS DETERMINED BY 
ORB REGISTER BIT 


DDRA I "O" (INPUT) 
I 
MPU WRITES INTO ORA. BUT 


MPU READS LEVEL ON PA PIN 


MPU RETDs IRA BIT wHIcH Is THE 
LEvEL OF THE PA PIN AT THE TIME 
OF THE LAST CA1 AcTIvE 
TRANsITIoN 


MPU READS LEVEL ON PA PIN 


(INPUT LATCHING DISABLED) 
NO EFFECT ON PIN LEVEL 


DDRA - "0" (INPUT) 


t 
_ 
_ 


I 


I 
I 


_. 
ii- 


4D 


FIGURE ‘I7. REGISTER 4, TIMER 1 LOW-ORDER COUNTER 
1' 
' 
- 
"0" 
ASSOCIATED PA PIN Is AN INPUT 
7 
(HIGH IMPEDANCE) 
"1" 
ASSOCIATED PA PIN Is AN OUTPUT 
WHOSE LEVEL Is DETERMINED BY 


I 
-I-— 


I 
‘I 
‘E 
— 
~32 


L_ 
A 
_ 
164 
‘ 


~ 
2 
2123 


WRITE - 8 BITS LOADED INTO T1 LOW-ORDER 
LATCHES. LATCH CONTENTS ARE 
TRANSFERRED INTO LOW-ORDER 
COUNTER AT THE TIME THE HIGH- 
ORDER COUNTER IS LOADED (REG 5). 
READ - 8 BITS FROM T1 LOW-ORDER COUNTER 
TRANSFERRED TO MPU. IN ADDITION. 
T1 INTERRUPT FLAG IS RESET (BIT 6 
IN INTERRUPT FLAG REGISTER). 


_ 
D 
15 
VALUE 


I 
I 
I 
1 -I 
oRA REGIsTER BIT 


I 
2 
I 


I 
I 
I 
4 
1 


I 
3 
COUNT 


I 
I 
UNTIL DDRA CHANGED 


I 
I- DATA °"‘*E°T'°" 
FIGURE 16. REGISTER3 DDRA 
I 
A 
_ 
2 
P84-PA4 
REGISTER “B" (DDRB) 
' 
-A 
A 
-AMA 
laanaana 


I 
i 
_ 
‘ 
I 
I 


._~ 
‘I P87/PA7_J 


"0" 
'AssocIATED PB PIN IS AN INPUT 
I 
I 


I 


PA1 


PA2 


MPU READS IRA BIT, WHICH IS THE 
LEVEL OF THE PA PIN AT THE TIME 
OF THE LAST CA1 ACTIVE 
TRANSITION 


PA1; DATA DIREcTIoN 


PA4 


PAS 


PAGI 


PA7_, 


REGISTER “A" (DDRA) 
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FIGURE 18. REGISTER 5, TIMER 1 HIGH-ORDER 
COUNTER 
lill 


I 
I 
I 
I 
|*—-zss "I 


I 
512 


I 
I024 
I 
we __ COUNT 


I 
P 
PP" 


I 
*8192 
( 


+ 


I 
ll) 
I I 
I 
- 16384 


I 32765 


WRITE - 8 BITS LODED INTO T1 HIGH-ORDER 
LATCHES. ALSO. AT THIS TIME BOTH 
HIGH- AND LOW-ORDER LATCHES 
TRANSFERRED INTO T1 COUNTER. 
T1 INTERRUPT FLAG ALSO IS RESET. 
READ - B IBTS FROM T1 HIGH-ORDER COUNTER 
TRANSFERRED TO MPU. 


FIGURE 20. REGISTER 7, TIMER 1 HIGH-ORDER LATCH 


I 
I——— 256 T 


512 
I 


1024 
I 


2°48 
___ COUNT 


I, 
_. 
— B192 


I 
. 
_. 
-. 


A 
16384 


WRITE - B BITS LOADED INTO T1 HIGH-ORDER 
LATCHES. UNLIKE REG 4 OPERATION 
NO LATCH-TO-COUNTER TRANSFERS 
TAKE PLACE. 
READ - B BITS FROM T1 HIGH-ORDER LATCHES 
TRANSFERRED TO MPU. 


FIGURE 22. REGISTER 9, TIMER 2 HIGH-ORDER LATCH! 
COUNTER 



256 


512 


1024 


204s 


4096 


0:92 


16384 


Jzrse 


3276i 


2... 4096 
VALUE 


I 


I 
»— 
~ 
4096 
VALUE 


COUNT 
VALUE 


VL6522 - VL65C22 - VL65C22V 


FIGURE 19. REGISTER 6, TIMER 1 LOW-ORDER LATCH 


. 
1.. 


I 
\ 
I 
I 
——2 


I 
4 
I 


8 r_COUNT 
A-~ 
- 
»- 
P16‘ 
vALUE 
- 
— 
-32 


E- 
. E54 


‘- 
— 
~~ .2 
~12_sl 


WRITE - B BITS LOADED INTO T1 LOW-ORDER 
LATCHES. THIS OPERATION IS NO 
DIFFERENT THAN A WRITE INTO 
REG 4. 
READ - 8 BITS FROM T1 LOW-ORDER LATCHES 
TRANSFERRED TO MPU. UNLIKE REG 4 
OPERATION. THIS DOES NOT CAUSE 
RESET OF T1 INTERRUPT FLAG 


FIGURE 21. REGISTER 8, TIMER 2 LOW-ORDER LATCH! 
COUNTER 


7 
I 


Z 


I 
I 
4 
I 


I 
m. 
VALUE 
IIL-_--it-32 
l___.__:.,I 


WRITE - 
B BITS LOADED INTO T2 LOW-ORDER 
LATCH 
READ - 
B BITS FROM T2 LOW-ORDER COUNTER 
TRANSFERRED TO MPU. T2 INTERRUPT 
FLAG IS RESET. 


FIGURE 23. REGISTER 10, SHIFT REGISTER 
Blil 


I 
I‘ 
I 
l*____ 


‘ 
I 
_- 
I 
_ f REGIsTER 
~_L_ 
_ 
_ 
BITS 


I‘ 


I 
i 
__ 
_ 
Ti 


L 
I 
‘I 
1 
*1 
Ti- 
NOTES; 


1. WHEN SHIFTING OUT. BIT 7 IS THE FIRST BIT 
OUT AND SIMULTANEOUSLY IS ROTATED BACK 
NTO BIT 0. 
want 
IIaITsLoAo:DINTo TTIIIGH ORDER 
' 
counnn ALSO_ Low ORDER LATcH 
2. IAIHEN SHIFTING IN, BITS INITIALLY ENTER 
mANsr ennso To Low onom 
an 0 AND ARE SITIFTED TowARDs sIT 7. 
COUNTER IN ADDITIDN. T2 INTERRUPT 
FLAG IS RESET 
MAI) 
IBITS FROM T2 HIGH ORDER COUNTER 
TRANSFERRED TO MPU 
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FIGURE 24. REGISTER 11A, AUXILIARY CONTROL 
REGISTER 


VL6522 - VL65C22 - VL65C22V 


Hilll 
I 
I 
I 
TI TIMER CONTROL 
A 
A 
-2] 
V7“6LO9ERATlON 
IP87 
_ 
0 0 nmsonmznnurr 
EACH TIME T1 IS 


1 
LLOADED 
DISABLED 
0 
1 commuous 


A 
i 
JNTERRUPTS 
_, 
i 
, 
1'0 nmso INTERRUPT 
\ owe-snot 
EACH TIME 11 IS 
OUTPUT 
_*_x_ i LOADED 
_; 
r 
I1 
1 
CONTINUOUS 
SQUARE 
I 
INTERRUPTS 
WAVE 
i 
I 
, 
IOLITPUT 
J 
I 


T2 TIMER CONTROL —~ 
* 
* 
* 
* * 
— 


s OPERATION 
,_ 
,0 TIMEDINTERRURT 


1 cou~1o0w~w|m 
PULSESON P86 


1* 
_ 
____ 
__ 


FIGURE 25. REGISTER 11B, AUXILIARY CONTROL 
REGISTER 
Hlll 
Lil 


SHIFT REGISTER 
MODE CONTROL 


_OPERATlON _ 
7 
DISABLED 
1 
7 
7W1 
7* .,*, 
w.» 
_ SHIFT_IN IJNDERCONTRO,L ofjz _ 
_, 
sung] IN UNDER CONTROL off-I-2 
1 
SHIFT IN UNDER CONTROL OF EXT cu< 
I 
I 
1 
SHIFT OUT F;RE*E-*RTLIN|\IlNGjAT T2 RATE T 
smrr our UNDER CONT_R,O_L of 12 


j SHIFTOUT UNDER CONTROL OF -1-, 
SHIFT our UNDER CONTROL OF sxrFcu<’ 


—*—* 
OOOB 
LP 
IR 


-Ioo--oo 


-InII 


o‘-c>-o-ow 


IfII 


O 


I 
71 
l 


_n_n 
I 


dI 


I 


i 
I 


FIGURE 27. REGISTER 13, INTERRUPT FLAG REGISTER 
Hlll 


, 
$121" BY 
~ 
CLEARED BY 


CA2 
CA2 ACTIVE EDGE 
READ OR WRITE 
REG 1 IORAI' 


A 
:1 ' 
R 
*1 
cA1 ACTIVE EDGE 
READ 0R wane 
_Rsc1IoRA) 
H 
COMPLETE 8 SHIFTS 
READ 0R WRITE 
_ SHIFT REG 


I REA0 0R wmre one- 


CA1 


‘ 
SHIFT REG 


cs2 Acnys eoqs 
ca1Ac11vE 5005 
TIME-OUT or T2 


CB2 
L-CB1 


~ 
LTIMER2 
READ on wane ORB 
“READ T2 Low*6R 
I W 
iwnyre T2 HIGH 
READ T1 LOW on 


_ wR|Te__T1 HIGH_ 
CLEAR ALL 
* 


I INTERRUPTS 


TIME-OUT or 11* 
—TIMERI 


ANY ENABLED 
INTERRUPT 
—IRO- 
1 


‘IF THE CA2/CB2 CONTROL IN ms PCR IS suscreo AS 
"uwozpsmoswr" INTERRUPT INPUT, mm READING on 
wamwc me ouwur REGISTER ORA/ORB WILL ~01 
CLEAR THE FLAG BIT. INSTEAD, ms an MUST RE_" 
CLEARED av WRITING mro me IFR, As osscmeso 
PREVIOUSLY. 


PB 
lo - DISABLE 
I 


I 


I 
L 


H 
I 
P“ 
LATCHENABLEDISABLE 


1= ENABLE LATCHINGI 


Rsmrr REGISTER CONTROL 


. 
;,*__,. 
_ 
__ 
_ 7 
OPERATION 
ff 
E’ 
, 
LOISABLED 
I 
j 
” 
i 
'1 


a 
‘L 
a 
,s_R|r1 m UNDER CONTROLWOF 12 
J 
{sum IN_UNDER,CONTR_OL 01312 
Lia 
_, 
_ 
Asmn m UNDER CONTROL or cx1.c_L_I<,_ 


A 
"T, 
VSHIFT our FREE-RUNNING A1 T2 RKATHE 
' 


I 
f 
IWXSHIFT our UNDERKCONTROL oF*12 ,1 
_ 
I0 SHIFT _OQT_UNDER CONTROL of p2 
f 
smrr 
OUIUNDER CONTROL or EXT. cu<.| 
F;---ooooI4> 
-_ 
AIn 
‘*1 


-0-IOO-0-0001.: 


4,4,1- 


--O-Io-ox: 


4!’ 


A-1 


I 


FIGURE 26. REGISTER 12, PERIPHERAL CONTROL 
REGISTER 


IHHHIIE 
I__ 
A 
I 
I 
_ 
I 
CB2 CONTROLA 
CA1 INTERRUPT CONTROL 


01 ~zcZ1|ve ACTIZQEKEOGEI 
1*=WPOS|TIVE Actwe zocg, 
of; 


‘I. 
U5 
1iOPERATION 
I 
_ 
I_NPLiT_NEGAjl\?E Ac1|I)£_£0c:1 
INDEPENDENT INTERRUPT 
I 
INPUT mo E_QGE* 
‘ 
C“ c°""‘°L 
I’ 
Ria 
’~ 
_ 
*1 


I 
INPUT POSI_TI\(E ACT_I\/_E_hE_D§_E 
I 
QP[RAT|0N 
0»1 
INDEPENDENT INTERRUPT 
0 
0 
INPUT NEGATIVE ACTIVE toot- 
, 
7 ‘|~Pu1Pos£oc£* 
i 
*-*"* 
- *" 
* 
* 
* 
""- 
. 
J 
_- 
_ ._._ 
|~6Eve~0£Rn INTERRDPT 
iHANDSHVA;KE OUTPLLT 
|~pU'|' ~[G E0651: 
I 
PULSE ourrur 
A 
-_; " 
' 
” 
‘T 


*5 
Q 
_ 
o 
io 


.-.4 
=11 


@ 
Q 
-A 
‘TO’ 


-ow 
-Tl 


I"r 


‘rL 
cfoé 
001.1 


'%4¥ 
III 


-I-1O 
NJ 
-IIi-I*5’ 
' 
—L-i 


1" 
1*. 
_ 
, 
i 


-L 


41' ii 
i1 
-01-A 
OIO 
-QIQ 
-0Q -I# 


_.__.. 
4 
, 
_, 
, ,_, _, 
_, 
__, 
|_~Pu_1|>o mvc ACTIVE cost 
J 
LOW ou11f_u_1, __ 
W 
more OUTPUT_ 
_ 
1% 
‘ 
i 
_~ 
IINIDEFENDENT INTERRUPT 
mvuT_f0s:gc:* 
_ 
L*f'* 


CB1 INTERRUPT CONTROL 


i; --I 
OO 
,44t*‘I 
rc 
-IIO 
-IIO‘41.1 


\_RANO_SHAKE oivur ___ 
_ 
PULSE_2UT_P_UT_ 
_ ____ 
Low ouwur 
I_?1,i<;T'0U1PU'F_i___] 
III - R’EGA1|\/£1 ACTIVETEOGE 
' 


I, 1 = POSITIVE ACTIVE soc: 


FIGURE 28. REGISTER 14, INTERRUPT ENABLE 
REGISTER 
. 
HHIHIIH 


I 
‘ 
I 


I 
I 
L CA2 
T 


I 
I 


I‘ 
, 
cA1 
‘ 


I 
‘ 
smrr REG 


I 
0 = INTERRUPT 
DISABLED 


INTERRUPT 
ENABLED 


CB2 
, 


I 
1 
= 


I 
* 
_ 
f 
-cs1 


‘ 
*TIMERZ 


* 
— 
'TIMER1 


i 
' 
* 
N 
SET/CLEAR; 


NOTES; 
1. IF BIT 7 IS A THEN EACH "1" IN BlTSO- 6 DISABLES THE 
CORRESPONDING INTERRUPT. 
2 IF BIT 7 IS A 
THEN EACH "I" IN BITSO - 6 ENABLES THE 
CORRESPONDING INTERRUPT. 
3. IF A READ OF THIS REGISTER IS DONE. BIT 7 WILL BE "I" AND 
ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE. 
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ABSOLUTE MAXIMUM RATINGS 
Ambient Operating 
Temperature 
-10 to +80°C 


Storage Temperature 
-65 to +150°C 


Supply Voltage to 
Ground Potential 
-0.5 to +7.0 V 


Applied Voltage 
-0.5 to +7.0 V 


Power Dissipation 
750 mW 


Stresses above those listed under 
"Absolute Maximum Ratings" may cause 
permanent damage to the device. 
These are stress ratings only. Func- 
tional operation oi this device at these or 


any other conditions above those 
indicated on the operational sections of 
this specification is not implied and 
exposure to conditions for extended 
periods may affect device reliability. 


DC, CHARACTERISTICS (VL6522): vcc -.= s v i5%, TA -.= o<>c to 1o<>c 
svmboi 
WEE 
<=~'\=""<>~= 
VIH 
V 
Input High Voltage 


VIL 
Input Low Voltage 
1—- 
—E 
"N 
Input Leakage Current 
i2 5 
PA 
VIN = 0 V IQ 5,0 V 
R/-W -RES RS3 
RSO -CS2 CS1 
CA1 O2 
' 
VCC = 0 V 
IT 
Input Leakage Current for Three State Off 
i1 0 
VIN = 0.4 V to 2.4 V 
3' 
07 00 
vcc = 5.25 v 


1]U 


oo 


oo 


Input High Current 
"H 
PA7 PAO CA2 PB7 PBO CB1 cez 
' 
nput 
ow 
urrent 
PA7 PAO CA2 PB7 PBO cs1 cez 
Output High Voltage 
VOH 
PA7 PAO CA2 PB7 PBO cet cez 


VOL 
Output Low Voltage 


IIL 


~ 
. 
_ 
PA7 PAO PB7 PBO 
IOH 
€"iP"itH'9h 
(Tl'L dnve) 07 no 
" 
UI'I'9R 
- 
(Sourcing) 
E2;-rl‘=;gn()other dnve, e.g 


IOL 
Output Low Current ( Sinking ) 


Output Leakage Current ( O State) 
IOFF 
_ 


' 
m 


E 


VIN = 2.4 V 


VIL = 0.4 V 


vcc .. 4.75 v 
ILOAD = -100 ILA 


VCC = 4.75 V 
ILOAD == 3.2 mA 


VOH = 2.4 V 


VOH = 1.5 V 


VOL = 0.4 V 


Q 
Power Dissipation 
m 


254 


w VLSI TECHNOLOGY, mc. 
VL6522 - VL65C22 - VL65C22V 


DC CHARACTERISTICS (VL65C22 AND VL65C22V): vcc = s v :I:5%, TA = ooc to 70°c 


Symbol 
Parameter 
T 
Condltlons 


IIEEEIHIEIIEEE 
3 
Eiii 
<<2 
§§§<< 


VIH 
Input High Voltage 
VCC 


VIL 
Input Low Voltage 
Input Leakage Current 
V|N . 0 V 10 5,0 V 
"N 
R/—W -RES RS3 
RSO -CS2 CS1 
CA1 D 
H 0 
VCC = 0 V 
Input Leakage Current for Three State Oit 
i 
VIN - 0.4 V to 2.4 V 
[)7 
[)0 
VCC - 5.25 V 


H 
Input High Current 
" 
PA7 PAO CA2 PB7 PBO cat ce2 
"L 
Input Low Current 
VIL B 0 4 V 
PA7 PAO CA2 PB7 PBO CB1 CB2 
' 


Output High Voltage 
vcc = 4,75 V 
VOH 
PA7 PAO CA2 PB7 PBO CB1 CB2 
ILOAD - -100 ILA 


O 
O 
VCC - 4.75 V 
V 
L 
utput Low Voltage 
ILOAD _ 3.2 mA 


ITSI 


VIN - 2.4 V 


_ 
PA7 PAC PB7 PBO 
OUTPUT Hlgh 
(1-|-L drive ), D7_D0 
VOH I 2.4 V 
IQH 
Current 
(sourcing) 
PB7-PBO ( other dnve, e.g 
VOH _ 1_5 V 
Darlington ) 


IOL 
Output Low Current ( Sinking ) 
VOL - 0.4 V 


Output Leakage Current (Ott State ) 
IOFF 
_|RQ 


ICC 
Power Supply Current 
MHZ 


CAPACITANCE: TA =-. 2s=>c, 1 = 1 MHz 


“R/—W, -RES, RS3-RSO, 
cs2,-cs1, 07-00, CA1 
CA2, PA7 PAO, 
7 ° 
PF 
- 
' 
' 
vcc - 5.0 v 
P 
VIN 
0V 
1-H! 
EI—E 
°°“T 
“II 
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VL65C816 


CMOS 16-BIT MICROPROCESSOR 


FEATURES 
- Advanced CMOS design for low 
power consumption and increased 
noise immunity 


- Single 5 V power supply 


- Emulation mode allows complete 
hardware and software compatibility 
with 6502 designs 


- 24-bit address bus allows access to 
16M bytes of memory space 


- Full 16-bit ALU, Accumulator, Stack 
Pointer, and Index Registers 


- Valid data address (VDA) and valid 
program address (VPA) output allows 
dual cache and cycle steal DMA 
implementation 


- Vector pull (VP) output indicates when 
interrupt vectors are being addressed 


- VP may be used to implement 
vectored interrupt design 


- ABORT input and associated 
vector supports interrupting any 
instruction without modifying internal 
registers 


- Separate program and data bank 


registers allow program segmentation 


- New Direct Register allows "zero 
page" addressing anywhere in first 
64k bytes of memory 


- 24 addressing modes: 13 original 
6502 modes plus 11 new addressing 
modes, with 91 instructions using 255 
opcodes 


- New Wait for Interrupt (WAI) and Stop 
the Clock (STP) instructions further 
reduce power consumption, decrease 
interrupt latency and allow synchroni- 
zation with external events 


- New Coprocessor (COP) instruction 
with associated vector supports 
coprocessor configurations (e.g., 
floating point processors) 


DESCRIPTION 
The VL65C816 is a CMOS 16-bit 
microprocessor featuring total software 
compatibility with its 8-bit NMOS and 
CMOS 6500-series predecessors. The 
VL65C816 extends addressing to a full 
16 megabytes. The device offers many 


advantages of CMOS technology, 
including increased noise immunity, 
higher reliability. and greatly reduced 
power requirements. A software switch 
determines whether the processor is in 
the 8-bit "emulation" mode or in the 
"native" mode, thus allowing existing 
systems to use the expanded features. 


The Accumulator, ALU, X and Y Index 
registers, and Stack Pointer Register 
have all been extended to 16 bits. A 
new 16-bit Direct Page Register 
augments the direct page addressing 
mode (formerly zero page addressing). 
Separate Program Bank and Data Bank 
Registers allow 24-bit memory address- 
ing. 


Four new signals provide the system 
designer with many options. The 
ABORT input can interrupt the currently 
executing instruction without modifying 
internal registers. Valid data address 
(VDA) and Valid program address (VPA) 
outputs facilitate dual cache memory by 
indicating whether a data segment or 
program segment is accessed. Modify- 
ing a vector is made easy by monitoring 
the vector pull (VP) output. 


PIN DIAG RAMS 


VL65C816 


ORDER INFORMATION- 
Part 
Clock 
Number 
Frequency 


VL65C816-02PC 
V51 
40 RES 


RDY 


ABORT 
'iT='i'6 
FL" 
Wi 
VPA 
voo 
Ao 
A1 
A2 
A3 
A4 
A5 
A6 
A7 
A8 
A9 
A10 
A1 1 


2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 


VDA 
M/X 
02 (IN) 
ea 
E 
R/V/' 
DO/BAO 
D1/BA1 
D2/BA2 
D3/BA3 
D4/BA4 
D5/BA5 
D6/BA6 
D7/BA7 
A15 
A14 
A13 
A12 
vss 


VL65C816-02CC 
VL65C816-04PC 
VL65C816-04CC 
VL65C816-06PC 
VL65C816-06CC 
VL65C816-08PC 
VL65C816-08CC 


2 MHz 


4 MHz 


6 MHz 


8 MHz 


Package 


Plastic DIP 
Ceramic DIP 
Plastic DIP 
Ceramic DIP 
Plastic DIP 
Ceramic DIP 
Plastic DIP 
Ceramic DIP 
Note: Operating temperature range is 0°C to +70°C. 


7 
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A0-A7 <2 


D0/BAO D7/BA7 
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M 


RLOW 
i 


ADDRESSBUFFE 


RHGH 


M 


1 
i 


ADDRESS 
BUFFE 


DATA 
BUS/BANK 
ADDRESSBUFFER 


BE 


INDEX X 
16 BITS 
<2 


INDEX Y 
(16 BITS) 


STACK POINTER 
(s) (is BITS) 
<>I<> 


(16 BITS) 
i 


TRANSFER 
“ 
SWITCHES 


Accuiiiiui.AToi=i 
(c) (ts BITS) 
_ 
(A) (a aiTs) 


~ 
(a) (a aiTs)IIiie 


ADDR 


RNAL 
PROG. COUNTER 
(PC) (16 BITS) 
NTE 


DIRECT (0) 
(ts BITS) 


(a aiTs) 
4-It 


DATA BANK (DBR) 
t 
(9 5'75) 
_ 
SYSTEM 


PROCESSOR 


, 
sTATus (P) 
N 
taairsi 
I_. 


l'\ 


1 
BTS 


inf 


ALBUS16 


NTERNAL 
SPEC 


DATA 


BTS 
C 


NDECODE 


TERMS 


DATA 
BUS 
16 


ER 
TRANSFER 
LOG 


NSTRUCT 
O 
SUMOFMN 
NTERNAL 


REG 
ST 


NSTRUCT 
O 


MN 


PREDECODE 


—l—l—L—l-L-rl—L—L 


= TRUE 
= RESULT ZERO 
= DISABLE 
= TRUE 
= 8 Bl1j0= 16 BIT 
= 8 5|-E 0 = 15 B|1- 
I: = 6502 
Accumulator (C) 
Accumulator 
= TRUE 
Registers 


= NEGATIVE 


I"""lI""1I""'1I"I III 
Ull 
QlllIII 
IIII 
I 
olI°|I 


I 


EBis:I 


zTta—B5111 T115. 
Y Register Hi 
(Y) Y Register Low 
_.ieB5> 
YH 


ABORT 
i 
INTERRUPT 


NMI 


RES 


N 
DECODE 


TERMS 


INSTRUCTION REGISTER 
- 
(a BITS) 


FIGURE 1 STATUS REGISTER 
FIGURE 2. PROGRAMMING MODEL 


STATUS REG. (P) 
E 
EMULATION 1 = eso2 
NVMXD 
I 20 
°=NAT"/E 


CARRY 
ZERO 
IRQ DISABLE 
DECIMAL MODE 
INDEX REG. SELECT 
MEMORY SELECT 
OVER FLOW 
NEGATIVE 


e aiTs 


5'ia_a'arT<'Re§. 
x Register Hi 
X x Register Low 
XH 
I I 
XL 


SI-I 


O 


VL65C816 


BLOCK DIAGRAM 


TIMING 
CONT. 


CLOCK 
GEN- 
ERATOR 


<4-- 
Voo 


4--— Vss 


RDY 


4321'") 


R/W 


VPA 


VDA 


1T1. 


W» 


E 


iiii/x 


I'—_I 


I I I 8: I I 


@ 


U 
. 
. 
"'_ 
‘-'I'D 


Stack Register I'Il(S) Stack Reg Low 


Program Bank Reg 
Pro ram 
(PC) 
Counter 
(Pgl-I) 
PCL) 


Direct Reg I-Ii 
Direct Reg Low 
DH 
I I 
DL 
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SIGNAL DESCRIPTIONS 
VL65C816 


Slgnal 
Name 


ABORT 


A0-A15 


BE 


D0/BAO-D7/BA7 


E 


E6 


W 


M/X 


NMI 


c2 (tn) 


Pln 
Number 


3 


9-12, 22-25 


36 


33-26 


35 


4 


5 


38 


6 


37 


Slgnal 
Descrlptlon 


Abort - The ABORT input is used to abort instructions (usually due to an Address Bus condi- 
tion). A negative transition will inhibit modification of any internal register during the current 
instruction. Upon completion of this instruction, an interrupt sequence is initiated. The 
location of the aborted opcode is stored as the return address in stack memory. The Abort 
vector address is OOFFF8, 9 (Emulation Mode) or OOFFEB, 9 (Native mode). Since ABORT is 
an edge-sensitive input, an Abort occurs whenever there is a negative pulse (or level) on the 
ABORT line during a phase 2 clock. 


Address Bus - These 16 output lines form the Address Bus for memory and I/O exchange on 
the Data Bus. The address lines may be set to the high-impedance state by the Bus Enable 
(BE) signal. 


Bus Enable — The Bus Ergble input signal allows external control_<_>f the Address and Data 
Buffers, as well as the R/W signal. With Bus Enable high, the R/W and Address Buffers are 
active. The Data/Address Buffers are active during the first halt of every cycle and the 
second half of a write cycle. When BE is low, these buffers are disabled. Bus Enable is an 
asynchronous signal. 


Data/Address Bus - These eight lines multiplex address bits BAO-BA7 with the data value. 
The address is present during the first half of a memory cycle, and the data value is read or 
written during the second half of the memory cycle. Two memory cycles are required to 
transfer 16-bit values. These lines may be set to the high impedance state by the BE signal. 


Emulation Status - The Emulation Status output reflects the state of the Emulation (E) Mode 
flag in the Processor Status (P) Register. This signal may be thought of as an op code 
extension and used for memory and system management. 


Interrupt Request - The Interrupt Request input signal is used to request that an interrupt 
sequence be initiated. When the IRQ Disable (I) Flag is cleared, a low input logic level 
initiates an interrupt sequence after the current instruction is completed. The Wait for 
Interrupt (WAI) instruction may be executed to ensure the interrupt is recognized immedi- 
ately. The lnterrupt Reguest vector address is OOFFFE,F (Emulation Mode) or 0OFFEE,F 
(Native mode). Since IRQ is a level-sensitive input, an interrupt occurs if the interrupt source 
was not cleared since the last interrupt. Also, no interrupt occurs if the interrupt source is 
cleared prior to interrupt recognition. 


Memory Lock - The Memory Lock output may be used to ensure the integrity of Read- 
Modify-Write instructions in a multiprocessor system. Memory Lock indicates the need to 
defer arbitration of the next bus cycle. Memory Lock is low during the last three or five cycles 
of ASL, DEC, INC, LSR, ROL, ROR, TRB, and TSB memory referencing instructions, de- 
pending on the state of the M flag. 


Memory/Index Select Status - This multiplexed output reflects the state of the Accumulator 
(M) and Index (X) Select Flags (bits 5 and 4 of the Processor Status (P) Register). Flag M is 
valid during the Phase 2 clock negative transition and Flag X is valid during the Phase 2 clock 
positive transition. These bits may be thought of as opoode extensions and may be used for 
memory and system management. 


Non-Maskable Interrupt - A negative transition on the NMI input initiates an interrupt se- 
quence. A high-to-low transition initiates an interrupt sequence after the current instruction is 
completed. The Wait for Interrupt (WAI) instruction may be executed to ensure that the 
interrupt will be recognized immediately. The Non-Maskable Interggt vector address ls 
00FFFA,B (Emulation Mode) or 00FFEA,B (Native Mode). Since NMI is an edge-sensitive 
input, an interrupt occurs ifmgre is a negative transition while servicing a previous interrupt. 
Also, no interrupt occurs if NMI remains low. 


Phase 2 In - This is the system clock input to the microprocessor internal clock generator 
[equivalent to e0 (IN) on the 6502]. During the low power Standby Mode, c2 (IN) should be 
held in the high state to preserve the contents of internal registers. 
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SIGNAL DESCRIPTIONS 


Slgnal 
Pin 
Slgnal 
Name 
Number 
Descrlptlon 
R/W 
34 
Read/\Nrite - When the R/W output signal is in the high state, the microprocessor is reading 
data from memory or I/O. When in the low state, the Data Bus contains valid d_a_ta from the 
microprocessor that is to be stored at the addressed memory location. The R/W signal may 
be set to the high impedance state by Bus Enable (BE). 


RDY 
2 
Ready - This bidirectional signal indicates that a Wait for Interrupt (WAI) instruction has been 
executed allowing the user to halt operation of the microprocessor. A low input logic level will 
halt the microprocessor in its current state. Returning RDY to the active high state allows the 
microprocessor to continue following the next Phase 2 In clock negative transition. The RDY 
signal is internally pulled low following the e>i<:ution of a W_a_i_t_for lgrrupt (WAI) instruction, 
and then returned to the high state when a RES, ABORT, NMl, or IRQ external interrupt is 
provided. This feature maybiused to eliminate interrup_tl£tency by placing the WAI instruc- 
tion at the beginning of the IRQ S8fVICI£Q_I'OUIIf'|8. lf the IRQ Disable Flag has been set, the 
next instruction is executed when the IRQ occurs. The processor does not stop after a WAI 
instruction if RDY has been forced to a high state. The Stop (STP) instruction has no effect 
on RDY. 


RES 
40 
Reset -The Reset input is used to initialize the microprocessor and start program execution. 
The Reset input buffer has hystggsis such that a simple R-C timing circuit may be used with 
the internal pull-up device. The RES signal must be held low for a _l_§§_t two clock cycles after 
VDD reaches operating voltage. Ready (RDY) has no effect while RES is being held low. 
During this Reset conditioning period, the following processor initialization takes place: 


_ 
Registers 
D 
= 
0000 
SH 
= 
01 
DBR 
= 
00 
XH 
= 
00 
PBR 
= 
00 
YH 
= 
00 
N 
V 
M 
X 
D 
I 
Z 
C/E 


P 
=[* 
* 
_1g_g1 
0 
1 
*g 
*/1|*=Notlnitialized 


STP and WAI instructions are cleared. 


Signals 
E 
= 
VQA 
= 0 
M/_1(_ 
= 
VP 
=1 
R/W 
= 
VPA 
= 0 
SYNC= 
O—L_A—L 


When Reset is brought high, an interrupt sequence is initiated R/W remains in the high state 
during the stack address cycles and the Reset vector address is 00FFFC,D. 


VDA, VPA 
39,7 
Valid Data Address and Valid Program Address - These two output signals indicate the type 
of memory being accessed by the address bus. The following coding applies: 


_;_; 
QQ 
6 


> 
<“U 
Internal oeration - Address and Data Bus available. 
Valid roram address - Ma be used for -- - ram cache control. 
Valid data address - Ma be used for data cache control. 
Op code fetch - May be used for program cache control and 
sin le step control. 


W5 
1 
Vector Pull - The Vectoull output indicates that a vector location is being addressed during 
an interrupt sequence. VP_is low during the last tw_o_interrupt sequence cycles, during which 
time the processor reads the interrupt vector. The VP signal may beused to select and 
prioritize interrupts from several sources by modifying the vector addresses. 


VDD 
8 
VDD is the 5 V supply voltage. 


VSS 
21 
VSS is system logic ground. 
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FUNCTIONAL 
DESCRIPTION 
The VL65C816 provides the design 
engineer with upward mobility and 
software compatibility in applications in 
which a 16-bit system configuration is 
desired. The VL65C816 16-bit hard- 
ware configuration, coupled with current 
software, allows a wide selection of 
system applications. In the Emulation 
Mode, the VL65C816 offers many 
advantages, including full software 
compatibility with 6502 coding. In 
addition, the powerful VL65C816 
instruction set and addressing modes 
make it an excellent choice for new 16- 
bit designs. 


The internal organization of the 
VL65C816 can be divided into two parts: 
1) the Register Section, and 2) the 
Control Section. Instructions (crop- 
codes) obtained from program memory 
are executed by implementing a series 
of data transfers within the Register 
Section. Signals that cause data 
transfers to be executed are generated 
within the Control Section. The 
VL65C816 has a 16-bit internal architec- 
ture with an 8-bit external data bus. 


INSTRUCTION REGISTER 
An opoode enters the processor on the 
Data Bus and is latched into the 
Instruction Register during the instruc- 
tion fetch cycle. This instruction is then 
decoded, along with timing and interrupt 
signals, to generate the various Instruc- 
tion Register control signals. 


TIMING CONTROL UNIT (TCU) 
The Timing Control Unit keeps track of 
each instruction cycle as it is executed. 
The TCU is set to zero each time an 
instruction fetch is executed, and is 
advanced at the beginning of each cycle 
for as many cycles as is required to 
complete the Instruction. Each data 
transfer between registers depends 
upon decoding the contents of both the 
Instruction Register and the Timing 
Control Unit. 


ARITHMETIC LOGIC UNlT(ALU) 
All arithmetic and logic operations take 
place within the 16-bit ALU. In addition 
to data operations, the ALU also 
calculates the effective address for 
relative and indexed addressing modes. 
The result of a data operation is stored 
in either memory or an internal register. 


® VLSI TECHNOLOGY, INC. 


Carry, Negative, Overflow and Zero 
Flags may be updated following the ALU 
data operation. 


INTERNAL REGISTERS (Refer to 
Figure 2, Programming Model.) 


ACCUMULATORS (A, B, C) 
The Accumulator is a general purpose 
register that stores one of the operands, 
or the result of most arithmetic and 
logical operations. In the Native Mode 
(E=0), when the Accumulator Select Bit 
(M) equals zero, the Accumulator is 
established as 16 bits wide (A+B=C). 
When the Accumulator Select Bit (M) 
equals one, the Accumulator is eight bits 
wide (A). In this case, the upper eight 
bits (B) may be used for temporary 
storage in conjunction with the Ex- 
change B and A Accumulator (XBA) 
instruction. 


DATA BANK REGISTER (DBR) 
During modes of operation, the 8-bit 
Data Bank Register holds the default 
bank address for memory transfers. 
The 24-bit address is composed of the 
16-bit instruction effective address and 
the 8-bit Data Bank address. The 
register value is mulitplexed with the 
data value and is present on the Data/ 
Address lines during the first half of a 
data transfer memory cycle for the 
VL65C816. The Data Bank Register is 
initialized to zero during Reset. 


DIRECT (D) 
The 16-bit Direct Register provides an 
address offset for all instructions using 
direct addressing. The effective bank 
zero address is formed by adding the 8- 
bit instruction operand address to the 
Direct Register contents. The Direct 
Register is initialized to zero during 
Reset. 


INDEX (X AND Y) 
There are two Index Registers (X and 
Y), which may be used as general 
purpose registers or to provide an index 
value for calculation of the effective 
address. When executing an instruction 
with indexed addressing, the micropro- 
cessor fetches the opcode and the base 
address, and then modifies the address 
by adding the Index Register contents to 
the address prior to performing the 
desired operation. Pre- or post-indexing 
of indirect addresses may be selected. 
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In the Native Mode (E=0), both Index 
Registers are 16 bits wide if the Index 
Select Bit (X) equals zero. If the Index 
Select Bit (X) equals one, both registers 
are 8 bits wide, and the high byte is 
forced to zero. 


PROCESSOR STATUS (P) 
The 8-bit Processor Status Register 
contains status flags and mode select 
bits. The Carry (C), Negative (N), 
Overflow (V), and Zero (Z) status flags 
serve to report the status of most ALU 
operations. These status flags are 
tested by use of Conditional Branch 
instructions. The Decimal (D), IRQ 
Disable (I), Memory/Accumulator (M), 
and Index (X) bits are used as mode 
select flags. These flags are set by the 
program to change microprocessor 
operations. 


The Emulation (E) Select and the Break 
(B) flags are accessible only through the 
processor Status Register. The 
Emulation mode select flag is selected 
by the Exchange Carry and Emulation 
Bits (XCE) instruction. Table 1, Com- 
patibility Issues, illustrates the features 
of the Native (E=O) and Emulation (E=-1) 
Modes. The M and X flags are always 
equal to one in the Emulation Mode. 
When an interrupt occurs during the 
Emulation Mode, the Break Flag is 
written to stack memory as bit 4 of the 
Processor Status Register. 


PROGRAM BANK REGISTER (PBR) 
The 8-bit Program Bank Register holds 
the bank address for all instruction 
fetches. The 24-bit address consists of 
the 16-bit instruction effective address 
and the 8-bit Program Bank address. 
The register value is multiplexed with 
the data value and presented on the 
Data/Address lines during the first half 
of a program memory read cycle. The 
Program Bank Register is initialized to 
zero during Reset. The PHK instruction 
pushes the PBR register onto the Stack. 


PROGRAM COUNTER (PC) 
The 16-bit Program Counter Register 
provides the addresses that are used to 
step the microprocessor through 
sequential program instructions. The 
register is incremented each time an 
instruction or operand is fetched from 
program memory. 
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STACK POINTER (S) 
The Stack Pointer is a 16-bit register 
stack addressing modes as well as 
that is used to indicate the next avail- 
subroutine and interrupt processing. 
able location in the stack memory area. 
The Stack Pointer allows simple 
It serves as the effective address in 
implementation of nested subroutines 


and multiple-level interrupts. During the 
Emulation Mode, the Stack Pointer high- 
order byte (SH) is always equal to one. 
The bank address for all stack 
operations is bank zero. 


PIN DESCRIPTIONS 


Pln 
, 
Descrlptlon 
_ i ,1 
_ 
__ 
_ 
Pln 
g 


I 
"*' 
_ 


; Descrlptlon 
_ 
g 
g 
f 
i 


A0-A15 
Address Bus 
- 
NC 
I 
! 
_ 
i 
E 
___ 
ii 
ABORT 
l Abort Input 
NM‘ 


I7 
_ 
__ 


. 
No Connection 


g 
g L Non-Maskable Interrupt 
_ 
BE_* 
W 
Bus Enable 
g 
A 
_g 
_ 
K 
T 
RDY 
Ready 
W i 
g 
_ 
i 
¢2 (IN) 
‘ 
Phase 2 In Clock 
RES 


_ 
I 
,_ 
7, 
~—- 
-e 
_ 


i___ 
I _ 
_ 
__ 


A 
Reset 


¢1 (OUT) 
Phaset Out Clock 
T 
R/W 
Read/Write 
M 
¢2(OUT) 
H 
Phase20utClock 
SO 


I-7 


. 
Set Overflow 
g 
f 
oo-or 
*DataBuLs 
g 
it 
T 
SYNC_ 
Synchronize 


D0/BAO—D7/BA7 
L Data Bus, Multiplexed 
VDA 
I 
Valid Data Address 


E 
g 
g 
ErnulatioriSelectW 
_ 
VP 
A W 
g 
TVector Pull 
i 
i 
I 
7 
H 


IRO 
M 
|nterruptRequestg 
g 
mVPA 
i 
Valid Program Address 
i 


_ 
T Memory Lock 
_ 
g 
W 
Voo 
~ 
Positive Power Supply (+5 Volts) 
_ 
L____ 
_._,_k 
. 
__ 
L_ 
E 
M/X 
_ 
‘ 
Mode Select (PM or Px) 
Vss 
g 
Internal Logic Ground 
g_ 
_ 


"I_____ 
' 
__ 
— 
—- 
— 
— 
_ 
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TABLE 1. COMPATIBILITY ISSUES 


ssce1s 
_ 
H 
g __ 
65C02 
NMOS 6502 


1. S (Stack) 
Always page 1 (E = 1), 8 bits 
16 bits when (E = 0). 
f 
Always page 1, 8 bits 
Alwayspage 1, e bits T I 2”“ 


""1-Ii_' 
ii 
2. X (X Index Register) 
Indexed page zero always in 
page 0 (‘E =1), 
Cross page (E = 0). 


Always page 0 
~ 
Always page 0 


3. Y (Y Index Register) 
Indexed page zero always in 
page 0 (E = 1), 
Cross page (E = 0). 


Always page 0 


l 
Always page 0 


If 
A (Accumulator) 
e bits (M = 1). 16 bits (M'= 0) 
8 bits 
Bbits 
_ 


____ 
_ 
1 
_ 
___ 
*5 
P (Flag Registor) 
N, V, and Z flags valid in 
decimal mode. 
D = 0 after reset or interrupt. 


.__1l 
__ 
N, V, and Z flags valid in 
decimal mode. 
D = 0 after reset and 
( 


N, V, and Z flags invalid 
in decimal mode. 
D = unknown after reset. 
interrupt. 
__D not modified after interrupt 
' 
_____J 
‘Tim 
I 
6 Timing 
A 
A. ABS. X ASL, LSR, ROL, 
ROR With No Page Crossing 


B. Jump Indirect 
Operand = XXFF 


C. Branch Across Page 


D. Decimal Mode 


7 cycles 


5 cycles 


4 cycles (E =1) 
3 cycles (E = 0) 


No additional cycle 


6 cycles 


6 cycles 


4 cycles 


Add 1cycle_* 
g 
_ 
g 
; 


7 cycles 


5 cycles and invalid page 
crossing 


4 cycles 


No additional cycle 
7 
BRK Vector 
I I 
OOFFFE,F (E_f_1)iK bit = 0 
on stack if IRQ. NMI. ABORT. 
00FFE6, 7 (E = 0) X = X on 
Stack always. 


FIZQF BRK bit = 0 on stack 
1 
if IRQ. NMI. 


7 
_1 


FF_I_=§,F_BjK on = 0 on stack 
if IRQ, NMI. 


__ 
__lO—I"‘t1 
ii 
3 
Interrupt or Break 
Bank Address 
PBR not pushed (E = 1) 
RTI PBR not pulled (E = 1) 
PBR pushed (E = 0) 
RTI PBR pulled (E = 0) 


Not available 
I 
Not available 


9 Memory Lock (ML) 
ML = 0 during Read, Modify and 
Write cycles. 
W = 0 during Modify and wine. 


L 
1 


Not available 


I0 Indexed Across Page 
Boundary (d),y; a,x; a,y 
Extra read of invalid address. 
Extra read of last instruction 
fetch. 
Extra read of invalid address. 


11 
RDY Pulled During Write 
Cycle. 
Processor stops 
Processor stops 
~ 
Ignored 


I? 
WAI and STP Instructions. 
Available 
Available 
Not available 


13 
Unused OP Codes 
w 
One reserved OP Code specified 
as WDM will be used in future 
systems. The 
65C816 performs 


No operation 
Unknown and some "hang 
up" processor. 


' 
7 
""*'*'*"""' 
' 
7i-i"JIli_i 
1 
14 
Bank Address Handling 
PBR = 00 after reset or interrupts 
Not available 
~ 
Not available 
is 
R/W During Read-M0dify- 
Write Instructions 
E = 1, R/W = 0 during Modify an 
Write cyc_les. 
E = 0, R/W = 0 only during 
Write cycle. 


a no-operation. 


d 
R/We 
only during Write cycle 
I 


I 


___ 
__ 
_7__ 
___*—I'*‘l 
' 
‘I 
l’ 
I 
‘I 


7'" 
b—1 
I 
I 
E 
E 
D 
E 
R/W = 0 during Modify and 
Write cycles. 
16 
Pin 7 
T 
VPA 
A 
SYNC 
SYNC 


i7 COP Instruction 
Signatures 00-7F user defined 
Signatures 80-FF reserved 


Available 


__ 
I 
__F"' 
7' 
Iuuf'7” 
Not available 
‘ 
Not available 
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TABLE 2. INSTRUCTION SET — ALPHABETICAL SEQUENCE 


ADC 
AND 
ASL 
BCC 
BCS 
BEQ 
BIT 
BMI 
BNE 
BPL 
BRA 
BRK 
BRL 
BVC 
BVS 
CLC 
CLD 
CLI 
CLV 
CMP 
COP 
CPX 
CPY 
DEC 
DEX 
DEY 
EOR 
INC 
_lNX 
INY 
JML 
JMP 
JSL 
JSR 
LDA 
LDX 
LDY 
LSR 
MVN 
MVP 
NOP 
ORA 
PEA 


PEI 


PER 


Add Memory to Accumulator with Carry 
"AND" Memory with Accumulator 
Shift One Bit Left, Memory or Accumulator 
Branch on Carry Clear (Pc = 0) 
Branch on Carry Set (Po = 1) 
Branch if Equal (Pz =1) 
Bit Test 
Branch if Result Minus (PN =1) 
Branch if Not Equal (Pz = 0) 
Branch if Result Plus (PN = 0) 
Branch Always 
Force Break 
Branch Always Long 
Branch on Overflow Clear (Pv = 0) 
Branch on Overflow Set (Pv = 1) 
Clear Carry Flag 
Clear Decimal Mode 
Clear Interrupt Disable Bit 
Clear Overflow Flag 
Compare Memory and Accumulator 
Coprocessor 
Compare Memory and Index X 
Compare Memory and Index Y 
Decrement Memory or Accumulator by One 
Decrement Index X by One 
Decrement Index Y by One 
"Exclusive OR" Memory with Accumulator 
Increment Memory or Accumulator by One 
Increment Index X by One 
Increment Index Y by One 
Jump Long 
Jump to New Location 
Jump Subroutine Long 
Jump to New Location Saving Return Address 
Load Accumulator with Memory 
Load Index X with Memory 
Load Index Y with Memory 
Shift One Bit Right (Memory or Accumulator) 
Block Move Negative 
Block Move Positive 
No Operation 
"OR" Memory with Accumulator 
. 
Push Effective Absolute Address on Stack (or Push Immediate 
TYX 
Data on Stack) 
Push Effective Indirect Address on Stack (or Push Direct 
Data on Stack) 
Push Effective Program Counter Relative Address on Stack 


For alternate mnemonlcs, see Table 7. 


TABLE 3. VECTOR LOCATIONS 


E = 1 
OOFFFE,F —lRO/BRK 
Hardware/Software 
OOFFFC,D—iE§ET 
Hardware 
OOFFFA,B—NMl 
Hardware 
OOFFF8,9 —ABORT 
Hardware 
OOFFF6,7 —-(Reserved) 
OOFFF4,5 -—-COP 
Software 


The VP output is low during the two cycles used for vector location access. 


PHA 
Push Accumulator on Stack 


VL65C816 


PHB 
Push Data Bank Register on Stack 
PHD 
Push Direct Register on Stack 
PHK 
Push Program Bank Register on Stack 
PHP 
Push Processor Status on Stack 
PHX 
Push Index X on Stack 
PHY 
Push Index Y on Stack 
PLA 
Pull Accumulator from Stack 
PLB 
Pull Data Bank Register from Stack 
PLD 
Pull Direct Register from Stack 
PLP 
Pull Processor Status from Stack 
PLX 
Pull Index X from Stack 
PLY 
Pull Index Y form Stack 
REP 
Reset Status Bits 
ROL 
Rotate One Bit Left (Memory or Accumulator) 
ROR 
Rotate One Bit Right (Memory or Accumulator) 
RTI 
Return from Interrupt 
RTL 
Return from Subroutine Long 
RTS 
Return from Subroutine 
SBC 
Subtract Memory from Accumulator with Borrow 
SEC 
Set Carry Flag 
SED 
Set Decimal Mode 
SEI 
Set Interrupt Disable Status 
SEP 
Set Processor Status Bite 
STA 
Store Accumulator in Memory 
STP 
Stop the Clock 
STX 
Store Index X in Memory 
STY 
Store Index Y in Memory 
STZ 
Store Zero in Memory 
TAX 
Transfer Accumulator to Index X 
TAY 
Transfer Accumulator to Index Y 
TCD 
Transfer C Accumulator to Direct Register 
TCS 
Transfer C Accumulator to Stack Pointer Register 
TDC 
Transfer Direct Register to C Accumulator 
TRB 
Test and Reset Bit 
TSB 
Test and Set Bit 
_ 
TSC 
Transfer Stack Pointer Register to C Accumulator 
TSX 
Transfer Stack Pointer Register to Index X 
TXA 
Transfer Index X to Accumulator 
TXS 
Transfer Index X to Stack Pointer Register 
TXY 
Transfer Index X to Index Y 
TYA 
Transfer Index Y to Accumulator 
Transfer Index Y to Index X 
WAI 
Wait for Interrupt 
WDM 
Reserved for Future Use 
XBA 
Exchange B and A Accumulator 
XCE 
Exchange Carry and Emulation Bits 


E = 0 
__ 
OOFFEE,F —lRO 
OOFFEC,D——-(gerved) 
OOFFEA,B—NMl 
OOFFE8,9 —ABORT 
OOFFE6,7 —BRK 
OOFFE4,5 —COP 


When an interrupt is executed, D = 0 and I = 1 in Status Register P. 
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Hardware 
Hardware 
Software 
Software 


M 
S 
D 
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TABLE 4. OPCODE MATRIX _ 
_ 
_ 
M__g 
_ 
_ 
_ 


BRKs 
° 
2 
6 


_ 
. 
. 
.. 
4 
4_...._._ 
._..-, 
A 
. B 
c 
W 
W1 


ORA (d,x) 
2 
6 


2 
3 
4 
5 
6 
7 
8 
D 
E 
F 
COPs 
ORAd§ Issac 
ORAd* 
2'6 
2'4 
2'6 
2 
3 


11 
_ 
__f 
ASLd 
ORA [<11 
PHPs 
2 
5 
2'6 
1 
3 
on/xii 
ASLAPHDs 
TSBa 
1'4 
3'6 
2 
2 
1 
2 
ORAa 
ASLa 
3 
4 
3 
6 
ORAal 
4'5 


11 
L. 
I 
BPLr 
2 
2 
1 
ORA(dLy 
2 
5 
f 


1!-% 
_1 
_ORA"(d) ORA _(d,s),y 
TRB <1 
ORA d,x 


4 2'5 
1 
J 
2 
4 
2 
2'5 


_ 
r 
1 
ASLd.x 
0RA*(d],y 
CLCI 
2 6) 
2 
6," 
1 
2 


111,11 
_ 
ORAay 
3 
4 
i1 
2 
INCA 
0 
TCSi 
TRBa 
1?? 
8'6- 
ORAa; 
3 
4 
3 
7 
ASLam Oaq 


JSRa 
3 
6 
I4 
BMIr 
2 
2 


2 


3 


AND(dm) 
2 
6 


AND(d)y 
2 
5 i 


11; 
1 l 
JsLm 
ANDd§ 
mra 
ANDd 
4'6 
2*4 
| 
2 
3 
2 
3 Iaota 
AND[m'CPLPs 
2 
5 
2'6 
1 
4 
ANDHI ROLA 
2 
2 
*1 
2 
PLD s 
BIT a 
1'5 
3 
4 
ANDa7 
ROLa 
3 
4 
3 
6 
ANDal 
4'5 


2 
1 
2'4 
IAND(d) AND(d,s).Y 
611 d,x AND d,x not d,x ANDJd],y 
SECi 
) 2'5 
" 
2 
4 
J 2 
6 
2 
6 
1 
2 
ANDay, 
3_tJ 
DECA 
1'2) 
TSCI 
BIT a,x 
1*2 
3'4 
ANDa$ ROLam 
3 
4 
3 
7 


—_ 
1_1 


ANDaL 
4*5 
Rs 
4 
1 
1 
EOR (d,x) 
2 
6 
~s#0 Kai 
2*4 
3'1 
son 6.3 
IMVP xyc 
eon <1 
2 
3 
LSRd 
EOR [<11 
PHAs 
2 
5 
2'6 
1 
3 
EOR# 
2 
2 
LSR A 


1 
2 
PHKs 
1'3 
JMPa 
3 
3 
EORa 
3 
4 
L 
LSRa 
3 
6 
EORal 
4'5 


BVCr 
5 
2 
2 
EORUy 
2 
5 
-1 


AJO 
Q2]“ES 


_J_ 
1_—_ 
1__ 
2'1 
3'1 


111 
I11 
_ 
1. 
EOR d,s).Y MVN xyc EOR d,x LSR d.x 
EORJd],y 
cue 
2 
4 
I 2 
6 I42 
6 
1 
2 
EORay 
3 
4 I1'3 
PHYs TCDi 
1*2 
IJMPaI 
1*4 
soaax 
3 
4 
|LSRam 
3 
7 
EORaL 
4'5 


RTSS 
6 
1 
6 
ADC(¢X) 
2 
6 


l__ 
.PERs| ADCd§ 
srze 
ADCd 
3'6 
2'4 
2 
3 
Leona 
ADC [<11 
PLAs 
ADC#" 
2 
2 
RORA RTLs 
1'6 
Jmeun 
(W3 
5 


111' 
__ 
ADCa .RORa 
3 
4 
3 
6 
ADCal 
4*5 


BVSr 
7 
2 
2 
ADCy 
2 
5 


' 2'3 
_ 
T 
sh 
ADC (6) ADC _(d,s).Y STZ d,x ADC d,x 
, 2'5‘ 
2 
1 
L2'4 
2 
4 


2 
5 
If 2'6 
1,4 
,RORd,x ADCJd],y 
SEIi 
2 
6 
2 
6 
1 
2 


“Ti 
ADCay 
3 
4 
PLYs 
1'4 


it 
2 
r 
TDCI 
1*2 


Tnmemx) 
3'6 
ADCa; 
3 
4 
RORBJ 
3 
7 
ADCaL 
4*5 


BRAr 
2'2 
a 


BCCr 
9 
2 
2 


STAGEM 
2 
6 
2*4 
BRLII 
STAd,s 
I STYd 
STAd 
3'3 
2 
3 
2 
3 


_1 
__ 
I 
STXd 
STA[d] 
DEYI 
2 
3 
2'6 
1 
2 


I 
mT# 
2'2 
I 
TXAi 


1 
2 
PHBs 
1'3 
I 
STYa 
3%*4 
STAa 
3 
4 
3 
4 
STXa 
snAm 
4'6 


STARDJI 
2 
6 


_. 
_L 
_ 
l_ 
__ __{ 
STA (d)-I STA d,$).Y 
STY d,x 
STA d,x STX d.Y I STAJd],y 
7 
2 
4 
2 
4 
2 
4 
2 
6 
2'6 
2' 
TYAI 
h 
W 
1 
2 
STAay 
3 
5 


I TXSI 


1 
2 
TXYI 
1'2 
ST2a 
3'4) 
STAam 
3 
5 
STZam 
3'5 
STAMJ 
4'5 


LDY# 
A 
2 
2 
LDA(¢x) 
2 
6 
Epxn 
LDAd§ 
Stove 
LoAd" 
2 
2 
*4 
2 
3 
3_4 
2 
2 


I 
T17 
l 
1_|. 
111. 
2 
3 
2'6 
1 
2 
LDXd 
LDA[d] -TAYI 
LDA# 
TAXI 


1 
2 


Q? 


PLBs 
1'4 I34 
LDYa 
I 
LDAa 
3 
4 
LDXa 
3 
4 
LDAaI 
4'5 


BCSr 
B 
2 
2 
LDAy 
2 
5 
LDA (d) 
‘ LDA &d,SI1Y 
LDY d,x 
LDA d,x 
2 
7 
2 
4 
2 
4 
2'5 
CUM 
LDX CIIYI LDA*Id],y 
2 
4 
2 
6 
1 
2 
LDAay 


2 
2 
I 


3 
4 
TSXI 


1 
2 
—-I *§ 
I\J_. 
LDYam 
3 4‘ 
LDAam 
3 
4 
ILDXay 
3 
4 
LDAaLx 
4*5 


CPY# 
C 
2 
2 


__J 
_ 
CMP (d,x) 
2 
6 


_ 
Ill 
7'_l__ 
REP#- cmpas 
2*3 
~ 
2*4 
CPYd 
2 
3 


1-23 
I 
‘i__j 
CMPdiDECd 
CMP[d] I-lNYi 
CMPII 
DEXI 
2 3g)2 
5 
2'6 
1 
2 
2 
2 
1 
2 
WAN 
1'3 I 
3 
4 
CPYa 
CMPa 
3 
4 
-DECa 
| 
3 
6 
CMPM 
4'5 


BNEr 
2 
2 


CPX# 
2 
2 


D 


E 


'1 .1 
CMP (d),y 
2 
5 


SBC(dm) 
2 
6 


CMP (d) CMP(d,s).y 
2'6 
2 
1 
Pas 
2'6 
cw <1: osc d,xI CMP*[d],y 
CLDI 
2 
4 
2 
6 
2 
6 
666., PHXs 
I 
1 
2 
3 
4 
1 
3 
STPI 
1'3 
JMLM) 
“*6 
CMP&x 
3 
4 
DECBJ 
3 
7 
CMPaL 
4'5 


_2*3 
2'4 
SEPII I 360.1,. IIcPx<1 
2 
3 
zseca l1~E{a 
sec [<11 
TINXI 
sec# 
NOPI 
2 
3 
2 5 
2'6 
1*2 
2 
2 
1 
2 
XBAI 
1'3 
CPXa 
3 
4 
SBCa 
3 
4 
IINCa 


_ 
3 
6 
SBCal 
4*5N 


BEOr 
F 
2 
2 
$66441 
2 
6 
SBC (d) SBC d,s).y 
2'5 
I 
'1 
2 
IPEAS 
3'6 
SBCd,x INCd,x 
SBCJd],y 
SEDi 
SBCa.y PLXs 
2 
4 
2 
6 
2 
6 
1 
2 
3 
4 
1'4 
XCEI 
JSR (a,x) 
SBCam 
INCax 
SBC aI,x 
1'2 
3'6 
3 
4 
3 
1 
4'5 


__r 
— 
FL 
1|; 
T 
_—l_ 
____ 
— 
_ 
_ 
— 
1 
——__ 
1 
11 
'1 
1 
_ 
0 
1 
2 
3 
4 
5 
6 
7 
8 
9 
A 
B 
C 
I 
I 
"IE1 


symbol 


H>:g 


H 
i 
s 
d 
dm 


dly 
Id) 
(d.X) 
why 


addressing mode 
symbol 


I-Q-I 
, 
1 
2 
., 
i 
I-1 
H? 


imnwdmm 
accumulator 
[d],y 
program counter relative 
program counter relative long 
I 
a,x 
immmd 
stack 
direct 


1 i 


direct indexed (with x) 
direct indexed (with y) 
direct indirect 
direct indexed indirect 
direct indirect indexed 


Id] 


3 


ay 
m 
mm 


Q 
ds 
1443 
(8) 
(en 
Iaqc 


addressing mode 


direct indirect long 
direct indirect long indexed 
absolute 
absolute indexed (with x) 
absolute indexed (with y) 
absohnelong 
absohnelongindexed 
stack relative 
stack relative indirect indexed 
absohneinduect 
absohneindexedinduect 
block move 


Op Code Matrix Legend 


INSTRUCTION 
ADDRESSING 
MNEMONIC 
* = New 
65c316 Opcodes 
MODE 
o = New 
65C02 Opcodes 


g 
BASE 
Blank = NMOS 6502 Opcodes 
BASE 
NO.BYTES 
NO.CYCLES 
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TABLE 5 


OPERATION 
_ 


(d).v 
[d1.v 
(dm) 
<i 
a=n"1Ti'O 


I 
'1 
'0 
>.~=<.."- 
"0107: 
=2: 
G 
I6 


I 
I 


‘C 


I 
ta) 
4\ 
V 
\v 
.1» 
1 
(6X) 
(d.$).v 
xyc 
Z 
~1 
< 
01 
§ 
U1 
XA Q 
Q 
-ro 
N)_6 O 
O 
M 
'1 
In 
I 


PROCESSOR 
STATUS CODE 
MNE_ 
1 
MONIC 
:0—: 
‘12I3I4" 
A 
567I69‘ 10 
11 
12 (13 
14 
16 
16 
17 
T6 
19 (20 
21 
22 
23 
24 
Z 
< 
CD 
U 
N 
O 
ITI : 
1 
7 
ADC’ 
A+M+c-A 
AND 
ASL 
BCC 
BCS 


AAM -__A________ 
C" 
I15./Z ._._.° 
BRANCH IF C = 
BRANcH IF c = -‘QI-I 
-0 


'69 6o'6FT66T 
3 
‘11 -"11 61* 
29 20 2F 
26 
I31 
31 
21 
06 
06 }oA 
* 


75, 


35 
16 


'10 l7F 
30 3F 
1E 
I 
I 


79 
if 
P P 
39 


90 
BO 


72 
32 


,.| 


67 
27 


I 
66115 
23 
33 
222 
-< 
NNN 0o 


ADC 
AND 
ASL 
BCC 
_ 
.. 
ecs_ 
BEOT 
TBRANCH IF z = 
BIT 
BMI 
BNE 
BPL 


-A 
AAM (NOTE 1) 
BRANCH IF N = 
BRANCH IF Z = 
BRANCH IF N = O 


O-A 


I 
_ 
i 
_IV 
_L 


89 
2C 
24 
I 
34 
. 
. 
| 
F0 
3C 
30 


. 
DO 
10 


I 
7 
; 
. 
BEO 


~ 
I 
z. 
BIT 
MrMs 
. 
. 


6 
6 
BMI 
BNE 
_ 
*_ 
. 
. 
. 
. 
BPL_ 


R BRA 
BRANCH ALWAYS 
T 
BRK 
BRL 
BVC 
BVS 


BREAK (NOTE 2) 
BRANCH LONG ALWAYS 
BRANCH IF v = 0 
BRANcH IF v = 1 
._.l 


,, 
,_ 


I 
80 


50 
70 


I 
I 
ZEBRA 
.O0I.. 
BRK 


6 
6 
6 
6 


6 
6 
6 


I 
I 
00 
82 
I 
P 
* 
BRL 
BVC 
i 
W 
ig 
f 
. 
. 
. 
BVSi 
"c|.c 
I T0-c 
CLD 
CLI 
0 
CLV 
CMP 


O-D 


)0 :<__ 
i 


— 


18 
I 
D8l 
58 


_ 
BB 
CQICDICFCS 
D1 
D7 C1 
D5 
I 
00.06 09 
102 c1 
cs 03 
I 


I 
_ 


I 


N 
.101 
0. 
.. 
ZC 


CLC 
CLD 
O. 
. 
CLI 
CLV 
CMP 
COP 
CPX 
CPY 
DEC 
DEX 
X0O 


ITI 


_,(')§§9I 


PROCESSOR 


-(X 
EMENT 
-~x 


E0 
EC 
E4 
‘ 
C0 CC 
C4 
. 
CE 
C6 
, 3A 
I 
CA 
; 
D6 


___ 
‘._._ 
_ 


DIE; 


I 
‘Z 
T 
IZITTWHZIZO2 


I 
I 
I 


ZZZZ 


6 
6 


6 
6 
6 


6 
6 
6 


6 
6 


6 
6 
NNNN 


OO 
OI..* 
COP 
CPX 
CPY 
DEC 
DEX 


DEY 
EOR 
INC 
INX 
INY 


- 
~Y 
—A 
EMENTS 
X+1~X 
Y+1~Y 
§§f 
4F 


I 
88 
. 
49 
4D 
45 
51 
571 41 
EE 
E6 
1A 
E8 
C8 
I 


55 
F6 
"I 
so 5F 691 
} 
62 
41 
; 


I 
FE 
\ 
-I 


l 


43 
53 


ZZZZZ 


6 
6 


6 
6 


6 
6 


6 
6 


6 
6 
NNNNN 


DEY 
EOR 
INC 
INX 
INY 
JML 
JMP 
JSL 
JSR 
LDA 


JUMP LONG TO NEW LOC. 
JUMP TO NEW LOC. 
JUMP LONG TO SUB. 
JUMP TO SUB. 
M —~ A 


I4CI5C 
I 
22I 


P 
I20 
I 
1A9 AD 
I 
B1 
B7 
A1 
AF 
A5 
B5 


L 


I 


FC 


_ 
DC 
I 
I 
6C 
7C 


BDTBF B9 
B2 A7 
iA3_,B3 
_ 
Z 


T 
H 
* 
JMLT 


N 


JMP 
JSL 
JSR 
LDA 


LDX 
LDY 
LSR 
MVN 
MVP 


M - X 
_. Y 
_ 
1' 
[15/.?_.-. Q]1 C 
- M BACKWARD 
-1 M FORWARD 
§§°§ 


.A2'A6 ”TA6i* 
. 
A0 Ac 
A4 
* 
46 
46 4A 
B4 
56 


. 
I 
. 
B6 
BE 
J 
BC 
I 
5E 
I 


, 54 
44 


oZZ 
NNN 
O ** 


LDX 
LDY 
LSR 
MVN 
MVP 
NOP 
ORA 
PEA 


PEI 


PER 
Mpc+rl,Mpc+rl+1-Ms—1,Ms 
( 


NOOPERATION 
AVM-A 
Mpc+1,Mpc+2-Ms-1,Ms 
S-2-S 
M(d),M(d + 1) - Ms-1,Ms 
S-2-S 
s-2-s 


09,00 OF 06 
11 
11‘ 01 
I 
_ 
‘ 
I 
I 
I 


‘ 
I 


15 


T___ 


I 
‘1o 1F,19 
12 
01 


I F4 


D4 


62 


03 
13 
N 
z 
‘k 


* 


‘k 


NOP 
ORA 
PEA 


PEI 


PER 


PHA 
PHB 
PHD 
PHK 
PHP 


A-Ms,S-1-S 
DBR-Ms,S-1-S 
D-—Ms,Ms-1,8-2-S 
PBR-Ms,S-1-S 
P-Ms.S-1—- (D 


E 
_ 
I 
~-iii 
~ 
4'6 
8B 
OB 
4B 


I 06 


I 


I 


I 


I 


‘k 
‘k 


PHA 
PHB 
PHD 
PHK 
PHP 
PHX 
PHY 
PLA 
PLB 
PLD 


>070) 


-Ms.S-1- 
-'Ms|S-1_. 
-S.Ms—- 
—-S,Ms-DBR 
—-S,Ms-1,Ms-D 
UHDCD-(X +++ -A-A 


I 
1 


L 
..‘._._ 
__ 


I 
I 
T611 


l 5A 
68 
AB 
2B 
ZZZ 
NNN 
‘k 
‘k 


PHX 
PHY 
PLA 
PLB 
PLD 
PLP 
PLX 
PLY 
REP 
gjtntntn>+++ ‘U-6-6-6 


—~S,Ms-P 
--S,Ms—-X 
—-S,Ms-Y 
—-P 
not 
I 
W 
-K 64' 


11 
f 
FTTI 


c2I 
36 


H 
I 
‘ 
‘ 


3E I 
I 


I FA 
7A 


TEST 
I 


ZZZZZ 
< ZZ 
><x UO 
NNN 


O0O 


6 
6 
6 
6 
6 


6 
6 
6 
6 
6 


N 


‘k 


PLP 
PLX 
PLY 
REP 
RoL_ 
R06 
i 
I-0- lip 
RTI 
I 
RTRN FROM INT. 
RTL 
I 
RTRN FROM SUB.LONG 
RTS 
SBC 
RTRN SUBROUTINE 


I 
A-M-6~A 


I 
I 


1 
26 
~26 2A; 


I 66 TTIT66 T6A 
I 


(66 6066 66 
I 
F1 
F7 
E1 


T16 


F5 


[7EI 
I 
~ 
I 
40 
6B 
60 63 F3 


*2 
.2‘-[ 
[ 
N 
N 


N 


1'/Nixoi 
V... 


NN 


6 


6 


O0 


zfc 


‘k 


ROR 
RTI 
RTL 
RTS 
SBC 
SEC 
SED 
SEI 
1 
SEP 
STA 


I 
1-c 


I 
1-o 
--I 
MVP-P 
A-M 
f 


I 
36 
F6 
I 


I 
, 
16 
‘ 


E2 
I 


I so BF 66 
,91~97 
81 
95 


‘ 
I 
FD 
I FF 
F9 
F2 
E7 


I 
‘ 
I 


9D 
9F 
99 
92 
87l 
‘83 
93 
N 
...1. 
....1 


1 
I 


VMXDIZC ‘k 


SEC 
SED 
SEI 
SEP 
STA 
STP 
STX 
STY 
STZ 
TAX 


‘ 
STOP(1-4:2) 
X-M 
-M 
—~M 
>8-< 
X 


06 
l 
66 
66 
1 
. 
ac 
64 
, 
I 
90 
64 
. 
I 


I 
AA 
I_ 
i 
___ 
*l_._i‘ 


94 
74 
9E 


I 


6 


6 


N 
i 


STP 
STX 
STY 
STZ 
TAX 
TAY 
TCD 
TCS 
TDC 
TRB 


U00) 
OCDQ-< 


€ 


to 


0-0 


E 


),... 
__ 


‘ 
A 
. 
.18 
‘7B 
I 
( 


I 
I 
V 
I 
_I 
I 
I 


;A6 
5B 


-AO 
-.65 
Q 
I 


I 
1 
"T1 N 
N 


N 


Z 
Z 


NN 
Q 
ii-W 


TAY 
TCD 
TCS 
TDC 
TRB 
TSB 
TSC 
TSX 
TXA 
TXS 


AVM-M 


XXUJUJ 
(0>><O 


i 


co 


g 


oO 
oA 


A 
13B 
. 


; 
BA 


I 
,6A 


6* 


‘ 
YQA 
I 


I 
‘...1.-.1- 


I 


I 
. 


1- 
I 
I 
I 
I 
I 
ll 
_I 
I 


I 
N 
N 
N 
NNNN 


‘O 
TSB 
TSC 
TSX 
TXA 
TXS 
TXY 
TYA 
TYX 
WAI 
I 
%VILDM 


co 
X 


X)-< 


Zo<<O 


_g 
i- RDY 
OPERATION (RESERVED) 
,, 
42 
I 


9B 
J 


I 
I98 
I 
BB 
‘ 
I 
I 
I 
CB 
‘ 
I 
\ 


I 
I 


I 


T4-I 


I 
J 
1 
I 


N 
N 
N 


6 
6 


6 
6 


6 
6 


6 
6 


6 
6 


Z 
Z 
Z 


‘k 


i'i'Qi- 


TXY 
TYA 
TYX 
WAI 
WDM 
XBA 
XCE 
OED --A 
-—-6 
i 
I 
FB 1* 
W 
1 
N 
Z 
6 
N- 
XBA 
xc6_ 


VLSI TECHNOLOGY, INC. 
VL65C81 6 


1 


2a 


2b 


2c. 


2d. 


*3a 


*3b 


*3c. 


43 


4b 


5 


6a 


*6b 


TABLE 6. DETAILED INSTRUCTION OPERATION 


. Immediate I 
(LDY,CPY,CPX.LDX,0RA, 
AND,EOR.ADC.BlT,LDA, 
(1)(8) 
CMP,SBC RERSEP) 
(14 Op Codes) 
(2 and 3 bytes) 
(2 and 3 cycles) 


. Absolute I 
(BlT.STY.STZ.LDY. 
CPY.CPX.STX,LDX. 
ORA,AND,EOR,ADC. 
STA.LDA.CMP.SBC) 
(1) 
(18 Op Codes) 
(3 bytes) 
(4 and 5 cycles) 
Absolute (R-M-W) I 


(ASL,ROL.LSR,ROR 
DEC,lNC.TSB.TR8) 
(6 Op Codes) 
(1) 
(3 bytes) 
(3) 
(6 and 8 cycles) 
(1) 


Absolute (JUMP) I 
(JMP)(4C) 
(1 Op Code) 
(3 bytes) 
(3 cycles) 


Absolute (Jump to 
subroutine) I 
(JSR) 
(1 Op Code) 
(3 bytes) 
(6 cycles) 
(ditterent order from N6502) 


. Absolute Long II 
(ORA.AND.EOR,AOC 
STA.LOA,CMP.SBC) 
(8 Op Codes) 
(4 bytes) 
(5 and 6 cycles) 
(1) 


. Absolute Long (JUMP) II 
(JMP) 
(1 Op Code) 
(4 bytes) 
(4 cycles) 


Absolute Long (Jump to 
Subroutine Long) II 
(JSL) 
(1 Op Code) 
(4 bytes) 
(7 cycles) 


. Direct d 
(8lT,STZ.STY.LDY. 
CPY.CPX,STX.LDX, 
(2) 
ORA,AND.EOR.AD_C. 
STA,LDA,CMP,SBC) 
(1) 
(18 Op Codes) 
(2 bytes) 
(3.4 and 5 cycles) 


. Direct (R-M-W) d 
(ASL,ROL.LSR,ROR 
DEC,lNC,TSB.TR8) 
(2) 
(6 Op Codes) 
(2 bytes) 


. Accumulator A 
(ASL.lNC.ROL.DEC.LSR.ROR) 
(6 Op Codes) 
(1 byte) 
(2 cycles) 


. lmpliedl 
(DEY. INY, INX. DEX. NOP. 
XCE, TYA, TAY,TXA, TXS. 
TAX.TSX.TCS.TSC,TCD. 
TDC.TXY,TYX.CLC.SEC. 
CLl,SEl.CLV.CLD.SED) 
(25 Op Codes) 
(1 byte) 
(2 cycles) 


(1) 
(5.6,7 and 8 cycles) 
(3) 
(1) 


1. 
2. 
2a 


A&(Jf\J-I~. 


—*(iiJI\)-I 
O‘lO'\U'l&b(¢-IR)-l ..N.~ 
.. 


-;>c.iro-» 
r..’ncn4>c.1-- 
-oiu\:~;..>ro- 


gapgamd 
-a:i~1giu1:~uro-» 


1. 
2. 
2a 


IO-IU'\U'1b(iiJ(J 


1. 
2. 


1 


1 


1 


—l—.—.—l—l 


—l-Q—lqIl—l—l-Q—lqIl—l—l—l 


Hdiidiidééddiuii 


—li_.—l—lqIl—.—lj—l-Q—-Q—l 


-1-A 
-I-I-I-I-I-0-J-I 


1 


1 


1 


1 


1 


—l—l—l—.q-I 


-A-I-I-A 
OQOOQ-I-A-I 


—.—A—l-Q-j—.—l—l-Il—l—l—l—.—l—l-l—l-Q 


—l—l-jj—l—l—l—l—l-Il1A—li—. 


-I-l 
QQQCQ-F-5-4‘ 


1 


1 


1 
O 
O 


-I-loo-I 


-loo-I-0-no-I-moo-A 


-eOOO-e-I-IOOO-I 
-'-I-‘O00-* 


-1-Ioo-0-I-A-loo-100-0 


O-A-I-no-I-moo-J 


1 


O 


1 


1 


1 


CO-I-I-I 


-A-I-A-A 
Q@Qc@_n-I-A 


-A-A-I-A-IOQ-I-I-I-I-nooo-I-A-A 


°oo—Q—l 
_l°o_loo_l-l—l 


O-IOOOOOO-I-8 


1 


O 


PBR,PC 
PBR,PC°1 
PBR_PC*2 


PBR,PC 
PBR,PC*1 
PBR_PC*2 
DBR_AA 
DBR,AA*1 


PBR_PC 
PBR,PC*1 
PBR,PC+2 
DBR,/\A 
DBR_AA+1 
DBR,AA'1 
OBR_AA*1 
DBR,AA 


PBFLPC 
PBR_PC+1 
PBR,PC+2 
PBR, NEW PC 


P8R_PC 
PBR,PC*1 
PBR_PC+2 
PBR,PC*2 
0.3 
0.5-1 
PBR_NEW PC 


PBR,PC 
PBF1_PC*1 
PBR_PC*2 
PBF1,PC*3 
AAB,AA 
AAB,AA+1 
P8R,PC 
PBR,PC+1 
PBFI,PC+2 
PBR_PC+3 
NEW PBR,PC 


PBR_PC 
PBR_PC*1 
PBR,PC*2 
0,5 
O.S 
PBR,PC+3 
0,3-1 
0.5-2 
NEW PBFLPC 
PBR,PC 
PBR_PC+1 
PBR,PCt1 
0,DvDO 
O.D+DO'1 


PBR,PC 
PBR,PC+1 
P8R,PC+1 
O,D+DO 
0.D+DO+1 
O,D+DO~1 
O.D+DO+1 
O.D+DO 
PBR.PC 
PBR,PC*1 


PBFLPC 
PBR,PC*1 


Implied I 
1. 
1 
1 
1 
1 
P8R,PC 
(XBA) 
2. 
1 
1 
0 
0 
P8R.PC+1 
(10pCode) 
3. 
1 
1 
0 
0 
PBR.PC~1 
(1 byte) 
(3 cycles) 


Op Code 
IDL 
IDH 


Op Code 
AAL 
AAH 
Data Low 
Data High 


Op Code 
AAL 
AAH 
Data Low 
Data High 
IO 
Data High 
Data Low 
Op Code 
NEW PCL 
NEW PCH 
Op Code 


Op Code 
NEW PCL 
NEW PCH 
IO 
PCH 
PCL 
Next Op Cod 
Op Code 
AAL 
AAH 
AAB 
Data Low 
Data High 
Op Code 
NEW PCL 
NEW PCH 
NEW BR 
Op Code 


Op Code 
NEW PCL 
NEW PCH 
PBR 
IO 
NEW PBR 
PCH 
PCL 
Next Op Code 
Op Code 
DO 
IO 
Data Low 
Data High 


Op Code 
DO 
IO 
Data Low 
Data High 
IO 
Data High 
Data Low 
Op Code 
IO 


Op Code 
IO 


Op Code 
IO 
IO 


ADDRESS moo: 
cvcu: W. "ii. VDA,VPA ADDRESS eus DATA eus 
R/Ti 


1 


1 


1 


4-0 
\\-A-I-IOO 


-A-I-A-I 
oo-A-I-O-0-I-I 


-Q—l 


-I_A_n_. 
\8_I-I-5-I 
-l°o—l-A-0-0 


O 


1 


"Too 
o---e 
\\-Q-I-I-Qiioo 


-I-A 
0°-I-I-Q-A-A-I 


1 


1 


1 
J 
15 
1 


06¢ 


06d 


7 


8 


9. 


10a. 


10b 


11 


12a 


12b 


*13. 


14 


ADDRESS MODE 
cvcua Tr, E. voA.vn ADDRESS Ius min Ius 
n/W 


Wait For Interrupt 
(WAI) 
(1 Op Code) 


Stop-The-Clock 
(STP) 
(1 Op Code) 
(1 byte) 
(3 cycles) 


See 21I Stack 


(9) 
(1 byte) 
____ 
(3 cycles) 
IRQ.NMl 


RES=1 
@=° 
§§§=° 
RE$=1 


(HardwIre interrupt) 


Direct Indirect Indexed (d).y 
(ORA,AND.EOR.ADC. 
$1'A.LDA.CMP,$BC) 
(2) 
(8 Op Codes) 
(2 bytes) 
($.6,7 and 8 cycles) 
(4) 


(1]l 


Direct Indirect 
Indexed Long [d].y 
(ORA,AND.EOR.ADC. 
(2) 
STA.LDA.CMP.SBC) 
(8 Op Codes) 
(2 bytes) 
(6.7 and 8 cycles) 
(1) 
Direct Indexed Indirect (d,x) 
(ORA.AND.EOR.ADC. 
S1'A.LDA.CMP.S8C) 
(2) 
(8 Op Codes) 
(2 bytes) 
(6.7 and 8 cycles) 


(1) 
Direct.X d.x 
(BlT.STZ.STY.LDY. 
ORA,AND.EOR.ADC. 
(2) 
$TA.LDA.CMP.SBC) 
(11 Op Codes) 
(2 bytes) 
(1) 
(4.5 and 6 cycles) 
Direct,X(R-M-W) d.x 
(ASL.ROL.LSR,ROR. 
DEC.lNC) 
(2) 
(6 Op Codes) 
(2 bytes) 
(6,7,8 and 9 cycles) 
(1) 
(3) 
(1) 


Direct,Y d,y 
(STX.LDX) 
(2 Op Codes) 
(2) 
(2 bytes) 
(4.5 and 6 cycles) 
(1) 
Absolute,X I,l 
(BlT.LDY,STZ. 
ORA,AND.EOR,ADC. 
STA,LDA,CMP,S8C) 
(4) 
(11 Op Codes) 
(3 bytes) 
(1) 
(4.5 and 6 cycles) 
Absolute.X(R-M-W) l,I 
(ASL.ROL.LSR,ROR. 
DECJNC) 
(6 Op Codes) 
(3 bytes) 
(7 and 9 cycles) 
(1) 
(3) 
(1) 


ORA AND.EOR ADC. 
STA LDA.CMP.S8C) 
8 Op Codes) 
4 bytes) 
(5 and 6 cycles) 
(1) 
Abs0lute,Y I,y 
(LDX,ORA,AND.EOR.ADC. 
TA.LDA,CMP.SBC) 
(9 Op Codes) 
(4) 
(3 bytes) 
(4.5 and 6 cycles) 
(1) 
Relative r 
(BPL.BMl.BVC,BVS,BCC. 
BCS.BNE.BEO.8RA) 
(5) 
(9 Op Codes) 
(6) 
(2 bytes) 
(2.3 and 4 cycles) 


Absolute Long.X l|,l 
( 
. 
. 


( 
‘ 


II 


S 


-l(_|,-I 


up- 
1c. 
tb. 
1I. 
1. 


1. 
2. 
2a. 
3. 
4. 


RJPO 
OIU‘lb(J?\JI\JU\U'\b 


;>wg~eg@w+@P.wg....P.vP.P 


-i\:ro-- 
4>I~uuro- 
oiu\A_u!~.1_- 
~i~io'>01uu><.->ro-.U~..m.m...~...P.~..... 


{iii 


ii-Qiiii 


—A_A—A—Q—l—A$l—l-Q-Q;-l—l—._.—lii—.—.-Q—.iII.—.i-Qaliqllc 


-A_l—A-do-I-A 
_n_I-n-I-11-A 
_...4-I-11-I-0-.-A-A 


Q-l—l—l—..j—l—l1A-Q-ll;-l—l—l-Il—O—l—. 
—.i—I§-.i—I§—.I@—'. 


“H 


-Q—l—l-Q—Q—|—l 


—l——l1Q—.-Q—.——|.xl—l—l-Q15—la1l—.—.—l-Q—l—O—.—l-Qiiqnli 


.¢-0-I-0..-e 
_o-I-I-Q-0-e 
Q()QQQ-0-A-I-0 


-Ioo-Q 


—*OOOOO-I 


-0-‘OCC-l 
-1-lC)(DQ-'* 
--O---Ooo-~ 


-‘CO-I 


-*OOOOO—~ 


QQQQ-0-ll 
OOOOOO-e-1OOOOOO-I-~ 
OOOOOO-I- 


COO-*—*-e 
COCO-‘-1) 
QOOQC)QC)—*—* 


JQQ-I-3 
QQQ-0-0-. 
QQ-0-1-F-I 
CQQQQQ-"‘-'-8 


-0°-I-I 


iii-Qqii-§ 


P8R_PC 
P8R.PC*1 
PBR.PC*1 
P8R,PC°1 


P8R_PC 
PBR_PC°1 
P8R,PC°1 
PBR.PC°1 
PBR,PC°1 
PBR,PC'1 
PBR_PC'1 


PBR,PC 
PBR,PC°1 
PBRPCQ1 
O,D*OO 
O,D°OO*1 
DBR,AAH.AAL* 
DBR,AA*Y 
DBR,AA*Y'1 
PBRPC 
P8F1,PC*1 
PBR,PC*1 
0.0°DO 
0,0‘ DO*1 
0,0*OO'2 
AAB,AA+Y 
AAB,AA*Y¢1 
PBRPC 
P8R.PC*1 
PBR,PC+1 
PBR.PC+1 
O,D*DO*X 
O.D+DO°X*1 
DBR,AA 
DBF1.AA+1 
PBR,PC 
P8R,PC¢1 
PBR.PC+1 
P8R.PC+1 
0.D+DO+X 
0.D*DO'X+1 


PBFLPC 
PBR,PC*1 
PBR,PC*1 
PBR,PC°1 
0,0*DO+X 
O.D*DO*Xt'1 
O,D+DO+X*1 
0.0*DO*X"1 
0_O+DO*X 


PBR_PC 
PBR,PC*1 
PBR,PC*1 
PBR,PC*1 
O,D+ DO*Y 
O,D*DO*Y°1 
PBR,PC 
PBR,PC*1 
PBR,PC*2 


Op Code 
IO 
IO 
lRQ(BRK) 


Op Code 
IO 
IO 
RES(BRK) 
F1E$(BRK) 
RES(BRK) 
BEGIN 


Op Code 
DO 
IO 
AAL 
AAH 
YL IO 
Data Low 
Data High 
Op Code 
DO 
IO 
AAL 
AAH 
AA8 
Data Low 
Data High 
Op Code 
DO 
IO 
IO 
AAL 
AAH 
Data Low 
Data High 
Op Code 
DO 
IO 
IO 
Data Low 
Data High 


Op Code 
DO 
I0 
IO 
Data Low 
Data High 
IO 
Data High 
Data Low 
Op Code 
DO 
IO 
IO 
Data Low 
Data High 
Op Code 
AAL 
AAH 
DBR.AAH,AAL+ XL IO 
DBR,AA+X 
DBR,AA*X*1 


PBR.PC 
PBR,PC*1 
PBR,PC*2 


Data Low 
Data High 


Op Code 
AAL 
AAH 
DBR,AAH,AAL* XL IO 
D8R,AA+X 
DBR,AA+X*1 
DBR.AA*X*1 
DBR,AA+X+1 
DBR,AA+X 


PBR,PC 
P8R,PC+1 
PBR,PC*2 
PBR,PC*3 
AAB,AA+X 
AAB.AA+X*1 


PBR,PC 
PBF1,PC*1 
PBR,PC*2 


Data Low 
Data High 
IO 
Data High 
Data Low 


Op Code 
AAL 
AAH 
AA8 
Data Low 
Data High 
Op Code 
AAL 
AAH 
DBR,AAH.AAL+YL IO 
DBR,AA*Y 
DBR,AA+Y*1 
PBRPC 
PBF1,PC+1 
PBR,PC+1 
PBR,PC+1 
P8R,PC+Ottset 


Data Low 
Data High 
Op Code 
Ottset 
IO 
IO 
Op Code 


“M 


iiqnl-Q-§—li 


-A-0 
-I-A 
-A-A 
-I-0 
\\_n_I-A_n\\-.I..I_n_a-I-g\\-A-I-A-0-0-I 
\\-I-1-I-0-A-A OD 
CO 
O0 
OQ 


-5-; 
-I4cc-. 
\\_n-I-I-I\\_I_I-0-A 
-I-I-I-I-I-ICO 
CO 


-41-I 
-I-I 


_n_n_I_a_.\\_._o_n-I\\_o-I-I-41 
QQ-I-I-I-I-I-0-I 


OO 
OO 


“S 
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TABLE 6. DETAILED INSTRUCTION OPERATION (c0NT.) 


ADDRESS MODE 


*16. Relative Long r1 
BRL) 


1 Op Code) 
3 bytes) 
4 cycles) 


17a. Absolute Indirect (I) 
(JMP) 
(1 Op Code) 
(3 bytes) 
(5 cycles) 


*17b. Absolute Indirect (I) 


(JML) 
(1 Op Code) 
(3 bytes) 
(6 cycles) 


I 18. Direct Indirect (d) 
(ORA,AND.EOR.ADC. 
STA.LDA,CMP,SBC) 
(2) 
(6 Op Codes) 
(2 bytes) 
(5.6 and 7 cycles) 
(1) 


*19. Direct Indirect Long [d] 
(ORA,AND.EOR,ADC 
$TA.LDA,CMP,SBC) 
(2) 
(8 Op Codes) 
(2 bytes) 
(6.7 and 8 cycles) 


I1) 
20a. Absolute Indexed Indirect (I,x) 
(JMP) 
(1 Op Code) 
(3 bytes) 
(6 cycles) 


*20b. Absolute Indexed Indirect 
(Jump to Subroutine Indexed 
Indirect) (a,x) 
(JSR) 
(1 Op Code) 
(3 bytes) 
(8 cycles) 


21a. Stack (Hardware 
Interrupts) I 
I3) 
(lRQ.NMl.ABORT,RES) 
(7) 
(4 hardware interrupts) 
(O bytes) 
(7 and 8 cycles) 


21b. Stack (Software 
Interrupts) I 
(3) 
(enmcop) 
(U 
(2 Op Codes) 
(2 bytes) 
(7 and 8 cycles) 


21c. Stack (Return from 
Interrupt) I 
(RTI) 
(1 Op Code) 
(1 byte) 
(6 and 7 cycles) 
(different order from N6$02) 
(7) 


21d. Stack (Return trOm 
Subroutine) I 
(RTS) 
(1 Op Code) 
(1 byte) 
(6 cycles) 


*21e. Stack (Return trom 
Subroutine Long) I 
(RTL) 
(1 Op Code) 
(1 byte) 
(6 cycles) 


268 


(3) 
- 


gW?9§N"?@9FPN**W#QN—~auw- 


-c>u\Auro- 
--o'1u\:><..1ro- 
-~io1u\ao.i_ro--cn~io1u-ia_up--m~1o~iu\:-_ur\>- 
-t:t:i~1_m5.i\zxg..no- 
-_m§J1_b§->!\J-e 
g*.°‘$-".5!-'§!’°.-‘ 


cvcu: V5.7; VDA,VPA ADDRESS eus oxrx eus 
RM 


—l—l-I-I-A-A-A 
-A-I-I-I-I-I-I 
-A-A-I-I-I-A 
-I-I-A-I-I 


-1.-A-A-A-I-I-A-I-A-A-0-;-I-I 
-I-I_I-A-I-I-5-I-noo_I-A-I-0-;-0-Ioo-A-I-A-I-A-I-A-A-I-5-n_g_g_;-I_g_g_g_g_g-;_‘_g_g_g_g_g_g_g-Q 


-0-.-I-I-I-I4 
-0.5-._._.-I-I 
-0-.-g_I_I..I_l—Q_._._. 


iiiiiiiiiiiiiiiijiiijiiiiii-Ilij—.—l-Q—l-Q—l—l—.j-Q-Q—l1l—.—l—.xIQ@—l{iiiiijiiiiiiil 


-5-4-5-.$@—l 
-4-0-5-FQO-I 
-I-5-I()o-I 
-IoQ@_a 


—~OOOOO-I-IOOOOO-I 
-OOOOOo- 
-IOQOOOO-I-e 
-OOOOOQQ-I 
-I-I-IO-IQO-A-I 
-I-I-10...... 
Qooooodd 
OOOQO-‘-' 
—*OOO-I-I.‘ 
.aQO_._x_a 
-Q_._._. 


PBR,PC 
PBR,PC*1 
PBR,PC*2 
PBR,PC*2 
PBR,PC+Otfset 


PBR,PC 
PBR,PC*1 
PBR,PC+2 
0,AA 
0.AA+1 
PBR.NEW PC 
PBR.PC 
PBR,PC*1 
PBR,PC°2 
O,AA 
O.AA*1 
0,AA+2 
NEW PBR,PC 
PBR,PC 
PBR.PC*1 
PBR,PC*1 
O,DtDO 
0,0tDO*1 
DBR.AA 
DBR_AA+1 


PBR,PC 
PBR,PC*1 
PBR.PC*1 
0.0*DO 
O.D*DO*1 
O.D*DO*2 
AAB.AA 
AAB,AA*1 
PBR.PC 
PBR_PCf1 
PBR,PC*2 
PBR.PC°2 
PBR_AA*X 
PBR_AA+X+1 
PBR. NEW PC 


PBR.PC 
PBR,PCt1 
0,5 
0,S—1 
PBR,PCt2 
PBR,PCt2 
PBR_AA+X 
PBR,AA*X+1 
PBR,NEW PC 


PBR.PC 
PBR.PC 
0,8 
0.8-1 
0.8-2 
0.S-3 
0.VA 
0,VA+1 
0.AAV 
PBR,PC 
PBR,PC*1 
O.S 
O.S—1 
0.S-2 


Op Code 
Otlset Low 
Offset High 
IO 
Op Code 
Op Code 
AAL 
AAH 
NEW PCL 
NEW PCH 
Op Code 
Op Code 
AAL 
AAH 
NEW PCL 
NEW PCH 
NEW PBR 
Op Code 
Op Code 
DO 
IO 
AAL 
AAH 
Data Low 
Data Low 


Op Code 
DO 
IO 
AAL 
AAH 
AAB 
Data Low 
Data High 
Op Code 
AAL 
AAH 
IO 
NEW PCL 
NEW PCH 
Op Code 
Op Code 
AAL 
PCH 
PCL 
AAH 
IO 
NEW PCL 
NEW PCH 
Next Op Cod 


IO 
IO 
PBR 
PCH 
PCL 
P 
AAVL 
AAVH 
Next Op Cod 
Op Code 
Signature 
PBR 
PCH 
PCL 
0.S-3 
(COPLatches) 
P 
O.VA 
0.VA+1 
0.AAV 
PBR.PC 
PBR_PC+1 
PBR,PCt1 
0,S*1 
0,S*2 
O,S*3 
0,S+4 
PBR,PC 


PBR,PC 
PBR,PCf1 
PBR,PCt1 
O,S+1 
O.S*2 
0.S+2 
PBR,PC 


PBR,PC 
PBR,PC*1 
PBR,PC*1 
O.S*1 
0.S*2 
0,S*3 
NEW PBR,PC 


AAVL 
AAVH 
Next Op Cod 
Op Code 
IO 
IO 
P 
PCL 
PCH 
PBR 
New Op Cod 


Op Code 
IO 
IO 
PCL 
PCH 
IO 
Op Code 
Op Code 
IO 
IO 
NEW PCL 
NEW PCH 
NEW PBR 


O 


O 


Next Op Code 


-4-I-I-I 


OO 


1 


211 


21g 


*21h 


*21i 


*21| 


*22 


*23 


*24a. 


*24b. 


Stack (Push) I 
(PHP,PHA.PHY,PHX. 
PHD,PHK.PHB) 
(7 Op Codes) 
(1 byte) 
(3 Ind 4 cycles) 
Stack (Pull) I 


Different than N6502) 
6 Op Codes) 
I byte) 
4 and 5 cycles) 


Stack (Push Ellective 
Indirect Address) I 
(PEI) 
(1 Op Code) 
(2 bytes) 
(6 and 7 cycles) 


Stack (Push Effective 
Absolute Address) I 
(PEA) 
(1 Op Code) 
(3 bytes) 
(5 cycles) 
Stack (Push Effective 
Program Counter Relative 
Address) I 
(PER) 
nmmwn 
(3 bytes) 
I6 cycles) 


Stack Relative d.I 
(ORA,AND.EOR,ADL. 
STA.LDA.CMP,SDC) 
(8 Op Codes) 
(2 bytes) 
(4 and 5 cycles) 


Stack Relative Indirect 
Indexed (d,I),y 
(ORA,AND,EOR,ADC. 
STA.LDA.CMP.SDC) 
(8 Op Codes) 
(2 bytes) 
(7 and 8 Cycles) 


Block Move Positive 
(forward) xyc 
(MVP) 
(1 Op Code) 
(3 bytes) 
(7 cycles) 
x = Source Address 
y = Destination 
. 


l 


(1) 


PLP,PLA,PLY,PLX,PLD_PLB) 


I1) 


(2) 


(1) 


(1) 


N-2 
Byte 
C=2 


c =Number of Bytes to Move -1 
x,y Decrement 
MVP is used when the 
destination start address 
is higher (more positive) 


N—1 
Byte 
C=1 


than the source start address. 


FFFFFF 
est. Start 


ource Start 
I 
Dest. End 
Source End 
000000 
FIFO 


Block Move Negative 
(backward) lyc 
mm) 
(1 Op Code) 
(3 bytes) 
(7 cycles) 
x = Source Address 
y = Destination 
c = Number of Bytes to M 
x,y Increment 


FFFFFF 
Source End 


Dest.End 
Source Start 
Dest. Start 


000000 


MVN is used when the 
destination start address 
is lower (more negative) 
than the source start 
address. 


N Byte 
Last 
C=0 


N-2 
Byte 
C=2 


ove -1 


N-1 
Byte 
C=1 


N Byte 
C=0 


PEN? 


bbl-FPO-IN 


t.nI>ooru-o1_u\I~<.1:’>yu_- 


U'lb(JIO-I 


6. 


auscu-P 


4- 
' 


.“9’°‘.**F~‘!’°.*‘ 
un- 


41 


—lN_O)_Lh_b_(J_hJ-0| 
~10Iu\Auro- 
i 
- 


iii-i 


-A-Jiiu-I 


ddmddddddd 


i-Q-Q-Q-Q 


qllcllii-Q 


ii.‘-A-1-5-1-J-4-I-liqiqi.iqA—l—l-lqii—l—l-li—l-5 


iii-J.‘-A-A 


-A-A-A-1-I-I-0-I-I-A-A-I-And-A 


i-Q-Q15 


—l—lii—l 


iiiii-Iii-ii-Ii 


u-Oi-I-ii 


1 


ii-‘ii 


Hdddd“dddddddddddddddddddd 


iqiiiii 


-Jqiqiiqji-liiicl-nd 


-I-no-I 


-Q—lO°_L 


-5-Jooii-1-5-5001 


—*QOO-I 


-I-Ioo-I 


--oo--oo~ 
oo--<90-oo--00- 
--0---OO- 


-IQQ-I-IQQ-lC)Q—l—lQQ-I 
@@-I-lQ@—l 


COO-I 


OOOO-' 


O0-I-1-I 
OOOQQ-0-I 


oo-A-I-I 


O 


COO-1-‘ 


-oooo--— 
oOOo---~oooo--- 
oooooo-— 


-lQOQO—l-I-*OOOO—e-I-I 
OOQQ—*-l-I 
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PBR,PC' 
PBR,PC*1 
0.5 
O.S-1 


PBR,PC 
PBR.PC*1 
PBR_PC+1 
O.$*1 
0,S¢2 


PBR_PC 
PBR.PC*1 
PBR,PC*1 
O.D+DO 
0,0*OO*1 
0,5 
0,8-I 


PBR,PC 
PBR.PC*1 
PBR.PC+2 
0.S 
O,S-1 


PBR.PC 
PBR_PC¢1 
PBR,PC°2 
PBR_PC*2 
0.3 


O_S-1 


PBR,PC 
PBR,PC'1 
PBR.PC*1 
0.S*$O 
0,$*SO*1 


PBR,PC 
PBR,PC+1 
PBR¢PC*1 
O.S+SO 
0.S*SO+1 
O.S*SO+1 
DBR,AA+Y 
DBR,AA+Y+1 
PBR,PC 
PBR,PC+1 
PBR.PC*2 
$BA,X 
DBA,Y 
DBA,Y 
DBA,Y 
PBR,PC 
PBR.PC*1 
PBR,PC*2 
$BA,X-1 
DBA,Y-1 
DBA,Y-1 
DBA,Y~1 


PBR_PC 
PBR,PC+1 
PBR.PC¢2 
SBA,X-2 
OBA.Y-2 
DBA,Y-2 
DBA,Y-2 
PBR.PCt3 


PBR,PC 
PBR,PC*1 
PBR,PC*2 
SBA.X 
DBA.Y 
DBA,Y 
OBA,Y 


P8R,PC 
PBR.PC+1 
PBR,PC*2 
SBA.X+1 
DBA,Y*1 
DBA,Y+1 
DBA,Y+1 


PBR.PC 
PBR,PC+1 
PBR,PC*2 
$BA,X+2 
DBA,Y*2 
DBA,Y+2 
DBA.Y'2 
PBR,PC*3 


Op Code 
IO 
Register High 
Register Low 


Op Code 
IO 
IO 
Register Low 
Register High 


Op Code 
DO 
IO 
AAL 
AAH 
AAH 
AAL 
Op Code 
AAL 
AAH 
AAH 
AAL 


Op Code 
Otlset Low 
Offset High 
IO 
PCH'OFF+ 
CARRY 
PCL*OFFSET 


Op Code 
SO 
IO 
Data Low 
Data High 


Op Code 
SO 
IO 
AAL 
AAH 
IO 
Data Low 
Data High 
Op Code 
DBA 
SBA 
Source Data 
Dest. Data 
IO 
IO 
Op Code 
DBA 
SBA 
Source Data 
Dest. Data 
IO 
IO 
Op Code 
DBA 
SBA 
Source Data 
Dest. Data 
IO 
IO 
Next0p Code 


Op Code 
DBA 
SBA 
Source Data 
Dest. Data 
IO 
IO 


Op Code 
DBA 
SBA 
Source Data 
Dest. Data 
IO 
IO 
Op Code 
DBA 
SBA 
Source Data 
Dest. Data 
IO 
IO 
Next Op Code 


ADDRESS none 
cvcu: W, FC,voA,vi>x ADDRESS aus amt eus 
it/W 


qqi—A 


ii-lad-Q 


QQ-I-0-e 
Q@...-I-I-1-0 


Q-0-0-I-I 


0 


-I-I \\40-Q-IOO 


0-lad 


1 


-I-no-A-1-I40 


-I-IQ-I-0-I-I 
-I-IQ-I-I-I-I 


1 
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TABLE 5. NOTES 
Notes: 
3. * = New 
65C816.'I"$"U¢1l0$ 
+ Add 
v on 
1. Bit immediate N and V flags not affected. When M = 0, M15 - N and M14 -V. 
0 = New 
65002 Instructions 
- Subtract 
V" Exclusive OR 
2. Break Bit (B) in Status register indicates hardware or software break. 
Blank = NMOS 6502 
A AND 


TABLE 6. NOTES 


Notest 
Abbreviations; 


(1) Add I byte (tor immediate only) for M=O or X=O (i.e. 16 bit data). add 1 cycle for M=O or X=O. 
AAB Ab$O|ute Address Bank 
(2) Add 1 cycle for direct register low (DL) not equal O. 


PBR or DBR registers will be updated. 


emulation mode. this cycle contains invalid addresses. 


(5) Add 1 cycle if branch is taken. 


(7) Subtract 1 cycle for 6502 emulation mode (E=1). 


j) Add 1 cycle lor REP,SEP. 


) Wait at cycle 2 for 2 cycles alter NMI or IRQ active input. 
$3 


(3) Special case for aborting instruction. This is the last cycle which may be aborted or the Status. 


(4) Add 1 cycle for indexing across page boundaries. or write, or X=0. When X=1 or in the 


(6) Add 1 cycle if branch is taken across page boundaries in 6502 emulation mode (E=1). 


AAH Absolute Address High 
AAL Absolute Address Low 
AAVH Absolute Address Vector High 
AAVL Absolute Address Vector Low 
C Accumulator 
D Direct Register 
DBA Destination Bank Address 
DBR Data Bank Register 
DO Direct Off 
t 
se 
IDH Immediate Data High 
IDL Immediate Data Low 
IO Internal Operation 
P Status Register 
PBR Program Bank Register 
PC Program Counter 
R-M-W Read-Modify-Write 
S Sta kAdd 
C 
ress 
SBA Source Bank Address 
SO Stack Offset 
VA Vector Address 
x.y Index Registers 
* = New 
$5C816"Addressing Modes 
I = New 
65C02 Addressing Modes 
Blank 
= NMOS 6502 Addressing Modes 


RECOMMENDED 
ASSEMBLER SYNTAX 
STANDARDS 
DIRECTIVES 
Assembler directives are those parts of 
the assembly language source program 
that give directions to the assembler; 
this includes the definition of data area 
and constants within a program. This 
standard excludes any definitions of 
assembler directives. 


COMMENTS 
An assembler should provide a way to 
use any line of the source program as a 
comment. The recommended way of 
doing this is to treat any blank line, or 
any line that starts with a semicolon or 
an asterisk, as a comment. Other 
special characters may be used as well. 


THE SOURCE LINE 
Any line that causes the generation of a 
single VL65C816 machine language 
instruction should be divided into four 
fields: a label field, the operation code, 
the operand, and the comment field. 


The Label Field - The label field begins 
in column one of the line. A label must 
start with an alphabetic character, and 
may be followed by zero or more 
alphanumeric characters. An assembler 
may define an upper limit on the number 


of characters that can be in a label, as 
long as that upper limit is greater than or 
equal to six characters. An assembler 
may limit the alphabetic characters to 
upper case characters if desired. If 
lower case characters are allowed, they 
should be treated as identical to their 
upper case equivalents. Other charac- 
ters may be allowed in the label, as long 
as their use does not conflict with the 
coding of operand fields. 


The Operation Code Field - The 
operation code consists of a three- 
character sequence (mnemonic) from 
Table 2. It starts no sooner than column 
two of the line, or one space after the 
label if a label is coded. 


Many of the operation codes in Table 2 
have duplicate mnemonics; when two or 
more machine language instructions 
have the same mnemonic, the assem- 
bler resolves the difference based on 
the operand. 


If an assembler allows lower case letters 
in labels, it must also allow lower case 
letters in mnemonics. When lower case 
letters are used in the mnemonic, they 


are treated as equivalent to the upper- 
case counterpart. Thus, the mnemonics 
LDA, Ida, and LdA must all be recog- 
nized, and are equivalent. 


In addition to the mnemonics in Table 2, 
an assembler may provide the alterna- 
tive mnerrionics shown in Table 7. 


SJL should be recognized as equivalent 
to JSR when it is specified with a long 
absolute address. JML is equivalent to 
JMP with long addressing force. 


The Operand Field - The operand field 
may start no sooner than one space 
after the operation code field. The 
assembler must be capable of at least 
24-bit address calculations. The 
assembler should be capable of 
specifying addresses as labels. integer 
constants, and hexadecimal constants. 
The assembler must allow addition and 
subtraction In the operand field. Labels 
are recognized by the fact that they start 
with alphabetic characters. Decimal 
numbers are recognized as containing 
only the decimal digits 0 through 9. 
Hexadecimal wnstants shall be 
recognized by preflxlng the constant 
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with a dollar sign ($) character, followed 
by zero or more of either the decimal 
digits or the hexadecimal digits A 
through F. If lower case letters are 
allowed in the label field, then they are 
also allowed as hexadecimal digits. 


All constants, no matter what their 
format, provide at least enough preci- 
sion to specify all values that can be 
represented by a 24-bit signed or 
unsigned integer represented in two's 
complement notation. 


Table 9 shows the operand formats that 
are recognized by the assembler. The 
symbol d is a label or value that the 
assembler can recognize as being less 
than #100.'The symbol a is a label or 
value which the assembler can recog- 
nize as greater than $FF but less than 
$10000; the symbol al is a label or value 
that the assembler can recognize as 
being greater than $FFFF. The symbol 
EXT is a label that cannot be located by 
the assembler at the time the instruction 
is assembled. Unless instructed 
otherwise, an assembler assumes that 
EXT labels are two bytes long. The 
symbols r and rl are 8- and 16-bit signed 
displacements calculated by the 
assembler. 


Note that the operand does not deter- 
mine whether or not immediate address- 
ing loads one or two bytes; this is 
determined by the setting of the status 
register. This forces the requirement for 
a directive or directives that tell the 
assembler to generate one or two bytes 
of space for immediate loads. The 
directives provided must allow separate 


settings for the accumulator and index 
registers. 


The assembler shall use the <, >, and '* 
characters after the # character in an 
immediate address to specify which byte 
or bytes are to be selected from the 
value of the operand. Any calculations 
in the operand must be performed 
before the byte selection takes place. 
Table 8 defines the action taken by each 
operand by showing the effect of the 
operator on an address. The column 
that shows a two-byte immediate value 
shows the bytes in the order In which 
they appear in memory. The coding of 
the operand is for an assembler that 
uses 32 bit address calculations, 
showing the way that the address 
should be reduced to a 24 bit value. 


In any location in an operand in which 
an address, or expression resulting in 
an address, can be coded, the assem- 
bler recognizes the prefix characters <, 
|, and >, which force one-byte (direct 
page), two-byte (absolute) or three-byte 
(long absolute) addressing. In cases in 
which the addressing mode is not 
forced, the assembler shall assume that 
the address is two bytes unless the 
assembler is able to determine the type 
of addressing required by context, in 
which case that addressing mode is 
used. Addresses are truncated without 
error if an addressing mode is forced 
that does not require the entire value of 
the address. For example: 


LDA 
$0203 
LDA 
$01 0203 


are completely equivalent. If the 
addressing mode is not forced, and the 
type of addressing cannot be deter- 
mined from context. the assembler 
assumes that a two-byte address is to 
be used. If an instruction does not have 
a short addressing mode (as in LDA, 
which has no direct page indexed by Y) 
and a short address is used in the 
operand, the assembler automatically 
extends the address by padding the 
most significant bytes with zeros in order 
to extend the address to the length 
needed. As with immediate addressing, 
any expression evaluation takes place 
before the address is selected; thus, the 
address selection character is only used 
once, before the address of expression. 


The exclamation point (I) character 
should be supported as an alternative to 
the vertical bar (|). 


A long indirect address is indicated in 
the operand field of an instruction by 
surrounding the direct page address 
where the indirect address is found by 
square brackets; direct page addresses 
that contains 16-bit addresses are 
indicated by being surrounded by 
parentheses. 


The operands of a block move instruc- 
tion are specified as source bank, 
destination band (the opposite order of 
the object bytes generated). 


Comment Field -The comment field may 
start no sooner than one space after the 
operation code field or operand code 
field or operand field, depending on 
instruction type. 


TABLE 7. ALTERNATIVE 
TABLE 6. BYTE SELECTION OPERATOR 
MNEMONICS 


Standard 
BCC 
BCS 
CMP A 
DEC A 
INC A 
JSL 
JML 
TCD 
TCS 
TDC 
TSC 
XBA 


Alias 
BLT 
BGE 
CMA 
DEA 
INA 
JSR 
JMP 
TAD 
TAS 
TDA 
TSA 
SWA 


Operand 
#$01020304 
#<$01020304 
#>$01020304 
ff "$01020304 


One Byte Result 
Two Byte Result 
04 
04 
03 
O4 
04 
O3 
O3 
03 
02 
02 
02 
01 
270 
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Absolute 


Absolute Long 


Direct Page 


Accumulator 
Implied Addressing 
Direct indirect 
indexed 


Direct Indirect 
Indexed Long 


Direct indexed 
Indirect 


Direct Indexed by X 


Direct indexed by Y 


Absolute Indexed by X 


Format 
#d 
#a 
sm 
#EXT 
#<d 
#<a 
#<al 
#<EXT 
#>d 
#>a 
#>al 
#>EXT 
#Ad 
#Aa 
#Am 
#AEXT 
M 
M 
a 
ml 
IEXT 
EXT 
>d 
>a 
>ai 
m 
>EXT 
d 
<d 
<a 
<al 
<EXT 
A 
(no operand) 
(d)»Y 
(<d).Y 
(<a).v 
(<al),y 
(<EXT),y 
idl.y 
i<di-Y 
i<al.v 
[<ai],y 
[<EXT],y 
id-X) 
(<d,x) 
(<a,x) 
(<ai,x) 
(<EXT,x) 
d,x 
<d,x 
<a,x 
<al,x 
<EXT,x 
d-Y 
<d,y 
<a,y 
<al,y 
<EXT,y 
d,x 
!d,x 
a,x 
!a,x 
!al,x 
!EXT,x 
EXT.x 


Addressing Mode 
Absolute Indexed by Y 


Absolute Long Indexed 
by X 


Program Counter 
Relative and 
Program Counter 
Relative Long 
Absolute indirect 


Direct indirect 


Direct Indirect Long 


Absolute indexed 


Stack Addressing 
Stack Relative 
indirect Indexed 


Block Move 


Note: The alternate I (exclamation point) is used in place of thel (vertical bar). 


Fonnat 
ldy 
d-Y 
ad 
lay 
kny 
!EXTy 
EXTy 
>d$ 
>ax 
>aLx 
aLx 
>EXT; 
d 


B 
ai 
EXT 
(dl 
(Id) 
(8) 
(la) 
(la ) 
(EXT) 
(dji 
(<8) 
(<al) 
(<EXT) 
id] 
i<al 
[<al] 
[<EXT] 
(d.><) 
(!d,x) 
(81) 
(!a,x) 
(!al,x) 
(EXT,x) 
(!EXT,x) 
(no operand) 
(d.$).y 
(<d,s),y 
(<8-$).y 
(<al,s),y 
(<EXT,s),y 
d,d 
d,a 
d,al 
d,EXT 
a,d 
a,a 
a,al 
a,EXT 
al,d 
al,a 
al,ai 
al,EXT 
EXT,d 
EXT,a 
EXT,al 
EXT, EXT 


VL65C816 


TABLE 9. ADDRESS MODE FORMATS 


Addressing Mode 
immediate 


(the assembler calculates 
r and rl) 



TABLE 10. ADDRESSING MODE SUMMARY 
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Memory Utilization 
Instruction Times 
In Number of Program 
__ W 
In Memory Cycles 
Sequence Bytes 


Address Mode 
Original 
8 Bit NMOS 


. 
55.92 


New 
65C816 
Original 
New 
8 BII NMOS 
65C816 
6502 


1. Immediate 
2. Absolute 
3. Absolute Long 
Direct 


I 
2 
4(5) 


3(5) 


O 2(3) 
4(3.5) 
5(3) 
3(3.4.s) 


2 


3 


f\) 


2(3) 


IO-BED 


5. Accumulator 
6. Implied 
7. Direct indirect indexed (d),y 
8. Direct indirect Indexed Long [d]. y 


2 
2 
5(1) 


2 


2 
5(1.3,4) 
5(s.4) 


m—A—A 


MN-A-5 


9. Direct indexed Indirect (d,x) 
10. Direct,X 
11. Direct,Y 
12. Absoiute,X 
_ 
_ 


6 
4(5) 
4 
4(1.5) 


5(1).-1) 
4(3.4,5) 


4(9).-1) 


4(1,3.5) 
O0I'\JI\)I'\J 
0iJ|\)I'\JI\) 


13. Absolute Long,X 
14. Absolute,Y 
15. Relative 
Relative Lon 


4(1) 
2(l.2) 


5(8) 
4(1.3) 
2(2) 
3 


2 


O0l‘\)(.)0-Ii 
16. 
g__ 
T N 
7 
""' 
gm 
T 
_ 
i 
WWW 
i 
_ 


17. Absolute indirect (Jump) 
18. Directlndirect 
19. Directlndirect Long 
20. Absolute Indexed Indirect (Jump) 
__ 
_ 
_ 
_g 


5 
5 
5(1).-1) 


5(1).-1) 


6 


3 


(iOl\)I\)O0 
21. Stack 
22. Stack Relative 
‘ 
- 
23. Stack Relative indirect Indexed 
—- 
_24. Block Move X, Y, C (Source, Destination. Block Length) 
_ 
— 
W 
g7g_ 
— 


3—7 
3-8 
4(3) 


7(3) 


31-3 
1-4 


2 


2 


3 
NOTES: 
1. Page boundary, add 1 cycle if page boundary is crossed when forming address. 
2. Branch taken, add 1 cycle if branch is taken. 
3. M = 0 or X = 0,16 bit operation, add 1 cycle, add 1 byte for immediate. 
4. Direct register low (DL) not equal zero, add 1 cycle. 
5. Read-Modify-Write, add 2 cycles for M = 1, add 3 cycles for M = 0. 
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ADDRESSING PREFACE 
The VL65C816 is capable of directly 
addressing 16M Bytes of memory. This 
address space has special significance 
within certain addressing modes. 


RESET AND INTERRUPT VECTORS 
The Reset and interrupt vectors use the 
majority of the fixed addresses between 
OOFFEO and OOFFFF. 


STACK 
The stack may use memory from 
000000 to OOFFFF. The effective 
address of Stack and Stack Relative 
addressing modes is always within this 
range. 


DIRECT 
The Direct addressing modes are 
usually used to store memory registers 
and pointers. The effective address 
generated by Direct, Direct X, and 


Direct Y addressing modes is always in 
Bank 0 (000000-OOFFFF). 


PROGRAM ADDRESS SPACE 
The Program Bank Register is not 
affected by the Relative, Relative Long, 
Absolute, Absolute Indirect, and 
Absolute Indexed indirect addressing 
modes or by incrementing the Program 
Counter from FFFF. The only instruc- 
tions that affect the Program Bank 
Register are: RTI, RTL, JML, JSL, and 
JMP Absolute Long. Program code may 
exceed 64K bytes, although code 
segments may not span bank bounda- 
ries. 


DATA ADDRESS SPACE 
The data address space is contiguous 
throughout the 16M Byte address 
space. Words, arrays, records, or any 
data structures may span 64k Byte bank 


boundaries with no compromise in code 
efficiency. The following 
addressing modes generate 24-bit 
effective addresses: 


- 
Direct Indexed indirect (d,x) 
- 
Direct Indirect Indexed (d), y 
- 
Direct Indirect (d) 
- 
Direct Indirect Long [d] 
- 
Direct indirect Long indexed [d], y 
- 
Absolute a 
- 
Absolute a, x 
- 
Absolute a, y 
- 
Absolute Long al 
- 
Absolute Long indexed al, x 
- 
Stack Relative Indirect Indexed (d), y 
The following addressing modes are 
available for use in the VL65C816 
microprocessor. Detailed descriptions of 
the 24 addressing modes are given in 
the following section. 


ADDRESSING MODES 


1. Immediate Addressing—# 
6. lmplied—i 
The operand is the second byte (second and third bytes when in the 
16-bit mode) of the instruction. 


Absolute—a 
With Absolute addressing the second and third bytes of the instruc- 
tion form the low-order 16 bits of the effective address. The Data 
Bank Register contains the high-order 8 bits of the operand address. 


instructioml 
opcodel 
addrl 
| 
Iaddirh 
| 
Operand 
I 
H 
Address: 
I 
DBR 
I 
addrh 
I 
addrl 
I 
Absolute Long—ai 
The second, third, and fourth byte of the instruction form the 24-bit 
effective address. 


lnstruction:| 
opcode 
| 
addrl 
I 
addrh 
I 
baddr 
| 
Operand 
W 
If 
Address: 
I 
baddr 
I 
addrh 
I 
addrl 
I 
Direct—d 
The second byte of the instruction is added to the Direct Register 
(D) to form the effective address. An additional cycle is req_u_i_red 
when the Direct Register is not page aligned (DL not eqal 0). The 
Bank register is always O. 


lnstructlon:( 
opcode 
I 
offset 
J 


I 
Direct Register 
I 


+ 
| 
offset 
I 


Operand 
I 
I 
I 
I 
Address: 
00 
effective address 
Accumulator—A 
This form of addressing always uses a single byte instruction. The 
operand is the Accumulator. 


Implied addressing uses a single byte instruction. The operand is 
implicitly defined by the instruction. 


Direct Indirect Indexed—(d),y 
This address mode is often referred to as lndirect,Y. The second 
byte ofthe instruction is added to the Direct Register (D). The 16-bit 
contents of this memory location is then combined with the Data 
Bank register to form a 24-bit base address. The Y Index Register is 
added to the base address to form the effective address. 


instructionzl 
opcode 
|Wo(fset 
I 


I 
Direct Register 


+ 
I 
offset 


I 
00 
I 
direct address 
then: 
00 
I 
(direct address) 


+I 
cert 
I 


base address 
I 


+ 
I 
I 
YR99 
I 
Operand 
I 
| 
Address: 
effective address 


Direct Indirect Long lndexed—[d],y 
With this addressing mode, the 24-bit base address is pointed to by 
the sum of the second byte of the instruction and the Direct 
Register. The effective address is this 24-bit base address plus the Y 
Index Register. 


10 Direct indexed With X—d,x 
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|"$Il’"¢Il°"= I g_QP¢0d<-1' 
I 
offset 
| 
lnstructlonzl 
opcode 
I 
offset 
I 


t 
I 
Offset 
I 
+ 
I 
offset 
. 


I 
00 
I 
direct 8ddI’BSS 
I 
diregt address 
I 
then: 
I 
I 
\ 
+ 
| 
i 
Y Reg 
1 
(direct address) 
-+ 
l 
i 
Yeeg 
Operand 
| 
Address: 
effective address 


Direct indexed indirect—(d,x) 
This address mode is often referred to as lndirect,X. The second 
byte of the instruction is added to the sum of the Direct Register 
and the X Index Register. The result points to the low-order 16 bits 
of the effective address. The Data Bank Register contains the high- 
order 8 bits of the effective address. 


Instruction: 
I jopcode 
l 
offset 
I 


I 
Direct Register 


+ 
I 
offset 


direct address 


+ 
I 
X Reg 


00 
address 
then: 


I 
00 
;‘ 
(address) 
, 


+ 
oee 


Direct Reglslei 
I 
Direct Register 


2 


3. 


Operand 
I 
14 
Address: 
effective address 


Thesecond byte of the instruction is added to the sum of the Direct 
Register and the X Index Register to form the 16-bit effective 
address. The operand is always in Bank 0. 


Instructionzl 
opcode 
I 
offset 
] 


I 
Direct Register 


+ 
I 
offset 


I 
direct address 
15' 


+l 
I 
X689 
I 
Operand 
I 
Address: 
00 
I 
effective address 
, 


11 Direct indexed With Y—d,y 
The second b te of the instruction is added to the sum of the Direct 
16' 
_ 
Y 
Register and the Y index Register to form the 16-bit effective 
address. The operand is always in Bank 0. 
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Operand 
I 
I 
Address: 
00 
effective address 
Absolute indexed With X—a,x 
The second and third bytes of the instruction are added to the 
X Index Register to form the low-order 16 bits of the effective ad- 
dress. The Data Bank Register contains the high-order8 bits of the 
effective address. 


Instruction: 
I (opoode 
l 
addrl 
addrh 


+ 


| 
oee 
I 
addrh 
addrl 


X Reg 


Operand 
I 
Address: 
effective address 


Absolute Long indexed With X—ai,x 
The second, third and fourth bytes of the instruction form a 24-bit 
base address. The effective address is the sum of this 24-bit address 
and the X Index Register. 
lnstructlon:| 
opcode 
I Taddri 
addrh 
I 
(baddr 
I 


+ 


I 
baddr 
I 
addrh 
addrl 


X Reg 


Operand 
I 
O 
Address: 
effective address 


Absolute indexed With Y—a,y 
The second and third bytes of the instruction are added to the 
Y index Register to form the low-order 16 bits of the effective ad- 
dress. The Data Bank Register contains the high-order8 bits of the 
effective address. 


lnstructioml 
opcode 
I 
addrl 
addrh 


+- 


I 
DBR 
I 
addrh 
addrl 


Y Reg 


Operand 
I 
Address: 
effective address 
Program Counter Relatlve—r 
This address mode, referred to as Relative Addressing, is used only 
with the Branch instructions. If the condition being tested is met, 
the second byte of the instruction is added to the Program Counter, 
which has been updated to point to the opcode of the next instruc- 
tion. The offset is a signed 8-bit quantity in the range from -128 to 
127. The Program Bank Register is not affected. 


Program Counter Relative Long—rl 
This address mode, referred to as Relative Long Addressing, is used 
only with the Unconditional Branch Long instruction (BRL) and the 
Push Effective Relative instruction (PER). The second and third 
bytes of the instruction are added to the Program Counter, which 
has been updated to point to the opcode of the next instruction. With 
the branch instruction, the Program Counter -is loaded with the 
result. With the Push Effective Relative instruction, the result is 
stored on the stack. The offset isasigned 16-bitquantityin the range 
from -32768 to 32767. The Program Bank Register is not affected. 


VLSI TECHNOLOGY, INC. 


ADDRESSING MODES (Cont.) 


17. 


18 


19 


20 


Absolute lndlrect—(a) 
The second and third bytes of the instruction form an address to a 
pointer in Bank O. The Program Counter is loaded with the first and 
second bytes at this pointer. With the Jump Long (JML) instruction, 
the Program Bank Register is loaded with the third byte of the 
pointer. 


Instructlon:I 
opcode 
I 
iaddrl 
I 
addrh 
I 


lndirectAddress= 
I 
00 
I 
addrh 
I 
addrl 
I 
New PC = (indirect address) 
with JML: 
New PC = (indirect address) 
New PBR = (indirect address +2) 


Dlrect lndlrect—(d) 
The second byte of the instruction is added to the Direct Register to 
form a pointer to the low-order 16 bits of the effective address. The 
Data Bank Register contains the high-order 8 bits of the effective 
address. 
23_ 


Instructlon:I 
opcodeI 
offset 
I 


+ 
I 
offset 
1 


Direct Register 


I 
00 
I 
direct address 
then: 


3 
00 
I 
(direct address) 
I 


+ 
DBR 
I 
Operand 
I 
Addfessi 
effective address 
I 


Dlrect lndlrect Long—[d] 
The second byte of the instruction is added to the Direct Register to 
form a pointer to the 24-bit effective address. 


lnstructlon:I 
opcode 
I 
offset 
I 


I 
Direct Register 
I 


+ 
I 
offset 
I 


I 
00 
I 
direct address 
I 
then: 
Operand 
Address: 
I 
(direct address) 
I 


Absolute Indexed lndlrect—(a,x) 
The second and third bytes of the instruction are added to the 
X Index Register to form a 16-bit pointer in Bank 0. The contents of 
this pointer are loaded in the Program Counter. The Program Bank 
Register is not changed. 


InstructIon:I 
opoode 
_ 
addrl 
addrh 


I 


131— 
L- 


l 
I I 
l 


‘ 
addrh 
addrl 


X Reg 


I 
PBR 
address 
then: 
PC = (address) 


VL65C81 6 


Stack—s 
Stack addressing refers to all instructions that push or pull data 
from the stack, such as Push, Pull, Jump to Subroutine, Return from 
Subroutine. Interrupts, and Return from Interrupt. The bank ad- 
dress is always 0. Interrupt Vectors are always fetched from Bank 0. 


Stack Relative—d,s 
The low-order 16 bits of the effective address is formed from the 
sum of the second byte of the instruction and the Stack Pointer. The 
high-order 8 bits of the effective address is always zero. The relative 
offset is an unsigned 8-bit quantity in the range of 0 to 255. 


lnstructlon:I 
opcodeI 
offset 
I 


I 
I 


+ 
ff I 
offset 
I 


Stack Pointer 
I 


Operand 
Address: 
I 
00 
I 
effective address 
I 


Stack Relative Indirect lndexed—(d,s),y 
The second byte of the instruction is added to the Stack Pointer to 
form a pointer to the low-order 16-bit base address in Bank 0. The 
Data Bank Register contains the high-order 8 bits of the base ad- 
dress. The effective address is the sum of the 24-bit base address 
and the Y Index Register. 


lnstructlon:I 
opcode 
I 
(offset 
I 


| 


+ 
I 
offset 


Stack Pointer 


I 
00 
I 
S + offset 
then: 


I 
S+offset 
+I 
oen 
I 


I 
I 
base address 
I 


+ 
I 
I 
YReg 
I 


Operand 
Address: 
I 
effective address 
I 


Block Source Bank, Destination Bank—xyc 
This addressing mode is used by the Block Move instructions. The 
second byte of the instruction contains the high-order 8 bits of the 
destination address. The Y index Register contains the low-order 16 
bits of the destination address. The third byte of the instruction 
contains the high-order 8 bits of the source address. The X Index 
Register contains the low-order 16 bits of the source address. The 
C Accumulator contains one less than the number of bytes to move. 
The second byte of the block move instructions is also loaded into 
the Data Bank Register. 
lnstructIon:I 
opcodeh 
I 
dstbnk 
Isrcbnk 
I 


dstbnk 
-' 
DBR 
Source 
Address: 
I 
scrbnk 
I 
XReg 
I 
Destlnatlon 
Address: 
I 
DBR 
I 
Y Reg 
I 


Increment (MVN) or decrement (MVP) X and Y. 
Decrement C (if greater than zero), then PC+3 —- PC. 
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TABLE 11. VL65C816 TIMING CHARACTERISTICS TA = 0°C to 70°C, VDD = 5.0 V 15% 


I 
2 MI-lz 
I 
4 
III 
6 MHz 
III 
8 MHz 
I 
_ 


CycleTime 
tcvc 
I 
500 
DC 
‘ 
250 
DC 
167 
DC 


II 
Parameter 
T 
II Symbol 
I 
Min 
Min 
MaxIII 
IIIMln IMax IIIIMln 
I MaxI 
Unit 


125 
I 
DC 
T 
nS 


' 
' 
' 
A 
7 
7 
. 
:7 
777 
7 7-1’ 
' 
1 
W 
. 
I 
I 
tpwt 
0.240 
w 0.120 
10 
0.050 
10 
0.050 
10 
#5 
ClockIP_ulse Width Low 
I 
10 
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tPwi-| 
240 
=» 
‘T 
120 
w 
so 
w 
so 
OO 
nS 
. 
_, 
, 
,,,_ 
, 
I 
,,_ 
.i 
I 
FallTime,RiseTime 
lF,tR 
I-I 
10 
- 
to 
I 
3-I 
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5 
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__ 
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__ 
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__ 
__ 
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7 
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_ 
_ 
__ 
__ 
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7 
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_ 
_ 
___7_ 
_7 
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I 
365 
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I 
87 
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7 
7777 
7 
— 
; 
_,_ 
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77 
.1 
____ 
11$“ 
ReadData Hold Time 
--i00 
tone 
"10 
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l 
10 
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nSII 
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_7 
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__ 
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I 
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E 
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-‘ 
____ 
_ 
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10 
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Capacitive Load (Address, DataI,Iand R/W) 
I 
Cexr 
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— 
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- 
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— 
I 
35 
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7: 
—|;7 
I35 
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____ 
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' 
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I 
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FIGURE 3. VL65C816 TIMING DIAGRAM 
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USER INFORMATION 
STACKADDRESSING 
When in the Native mode, the Stack 
Register may use memory locations 
000000 to OOFFFF. The effective 
address of Stack, Stack Relative and 
Stack Relative Indirect Indexed address- 
ing modes is always within this range. 
In the Emulation mode, the Stack 
address range is 000100 to 0001 FF. 
The following opcodes and addressing 
modes increment or decrement beyond 
this range when accessing two or three 
bytes: 


JSL; JSR(a,x); PEA; PEI; PER; 
PHD; PLD; RTL; d,s; (d,s),y 


DIRECT ADDRESSING 
The Direct Addressing modes are often 
used to access memory registers and 
pointers. The effective address gener- 
ated by Direct, Direct X, and Direct Y, 
addressing modes are always in the 
Native mode range 000000 to OOFFFF. 
When in the Emulation mode, the Direct 
addressing range is 000000 to 0000FF, 
except for [Direct] and [Direct] Y 
addressing modes and the PEI instruc- 
tion, which increment from 0000FE or 
0000FF into Stack area. 


When in the Emulation mode and DH is 
not equal to zero, the Direct addressing 
range is 00DH00 to OODHFF, except for 
[Direct] and [Direct] Y addressing modes 
and the PEI instruction which increment 
from OODHFE or 00DHFF into the next 
higher page. 


When in the Emulation mode and DL is 
not equal to zero, the direct addressing 
range is 000000 to OOFFFF. 


ABSOLUTE INDEXED ADDRESSING 
The Absolute Indexed addressing 
modes are used to address data outside 
the Direct addressing range. The 
65C02 addressing range is 0000 to 
FFFF. Indexing from page FFXX may 
result in a OOYY data fetch when using 
the VL65C02. In contrast, indexing from 
page ZZFFXX may result in ZZ+1,00YY 
when using the VL65C816. 


ABORT IN PUT(VL65C81 6 ONLY) 
ABORT should be held low for a period 
not to exceed one cycle. Also, if 
ABORT is held low during the Abort 
Interrupt sequence, the Abort Interrupt 


will be aborted. It is not recommended 
to abort the Abort Interrupt. The ABORT 
internal latch is cleared during the 
second cycle of the Abort Interrupt. 
Asserting the ABORT input after the 
following instruction cycles causes 
registers to be modified: 
- Read-Modify-Write: Processor Status 
Register modified if ABORT is 
asserted after a modify cycle. 
- RTI: Processor Status Register 
modified if ABORT is asserted after 
9-1/£'@.§-_. _..__ 
- IRO, NMI, ABORT BRK, COP: When 
ABORT is asserted after cycle 2, PBR 
and DBR become 00 (Emulation 
mode) or PBR becomes 00 (Native 
mode). 


The Abort Interrupt has been designed 
for virtual memory systems. For this 
reason, asynchronous ABORTS may 
cause undesirable results due to the 
above conditions. 


VDA AND VPA 
When VDA or VPA are high and during 
all write cycles, the Address Bus is 
always valid. VDA and VPA should be 
used to qualify all memory cycles. Note 
that when VDA and VPA are both low, 
invalid addresses may be generated. 
The Page and Bank addresses could 
also be invalid. This will be due to low- 
byte addition only. The cycle when only 
low-byte addition occurs is an optional 
cycle for instructions that read memory 
when the Index Register consists of 
eight bits. This optional cycle becomes 
a standard cycle for the Store instruc- 
tion, all instructions using the 16-bit 
Index Register mode, and the Read- 
Modify-Write instruction when using 8- 
or 16-bit Index Register modes. 


APPLE ll, lle, llc, AND ll+ DISK 
SYSTEMS 
VDA and VPA should not be used to 
qualify addresses during disk operation 
on Apple systems. Consult your Apple 
representative for hardware/software 
configurations. 


DB/BA OPERATION (WHEN RDY IS 
PULLED LOW) 
When RDY is low, the Data Bus is held 
in the data transfer state (i.e., o2 high). 
The Bank address external transparent 
latch should be latched when the 02 
clock or RDY is low. 
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M/X OUTPUT 
The M/X output reflects the value of the 
M and X bits of the processor Status 
Register. The REP, SEP, and PLP 
instructions may change the state of the 
M and X bits. Note that the M/X output 
is invalid during the instruction cycle 
following REP, SEP, and PLP instruction 
execution. This cycle is used as the 
opoode fetch cycle of the next instruc- 
tion. 


INSTRUCTIONS 
Opcodes - It should be noted that all 
opcodes function in all modes of 
operation. The following instructions 
have limited use in the Emulation mode: 


- The REP and SEP instructions cannot 
modify the M and X bits when in the 
Emulation mode. In this mode the M 
and X bits are always high (logic I). 


- When in the Emulation mode, the 
MVP and MVN instructions use the X 
and Y Index Registers for the memory 
address. Also, the MVP and MVN 
instructions can only move data within 
the memory range 0000 (Source 
Bank) to OOFF (Destination Bank). 


Indirect Jumps - The JMP (a) and JML 
(a) instructions use the direct Bank for 
indirect addressing, while JMP (a,x) and 
JSR (a,x) use the Program Bank for 
indirect address tables. 


Switching Modes - When switching from 
the Native mode to the Emulation mode, 
the X and M bits of the Status Register 
are set high (logic 1), the high byte of 
the Stack is set to 01, and the high bytes 
of the"X and Y Index Registers are set to 
00. To save previous values, these 
bytes must always be stored before 
changing modes. Note that the low byte 
of the S, X, and Y Registers and the low 
and high bytes of the Accumulator (A 
and B) are not affected by a mode 
change. 


How hardware interrupts, BRK, and 
COP instructions affect the Program 
Bank and the Data Bank Registers, 
when in the Native mode, the Program 
Bank register (PBR) is cleared to 00 
when a hardware interrupt, BRK or COP 
is executed. In the Native mode, the 
previous PBR contents are automatically 
saved. 
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USER INFORMATION (CONT.) 
Note that a Return from Interrupt (RTI) 
should always be executed from the 
same mode that originally generated the 
interrupt. 


Binary Mode-The Binary mode is set 
whenever a hardware or software 
interrupt is executed. The D flag within 
the Status Register is cleared to zero. 


WAI Instruction-The WAI instruction 
pulls RDY low and places the processor 
in the WAI low-power mode. NIT, W, 
or RESET terminate the WAI condition 
and transfer control to the interrupt 
handler routine. Note that an ABORT 
input aborts the WAI instruction, but 
does not restart the processor. When 
the Status Reg_i_s.t£ 1 flag is set (1% 
disabled), the IRQ interrupt causes the 
next instruction (following the WAI 
instruction) to be executed without going 
to the ll‘-TO interrupt handler. This 
method results i_n_tl\e highest speed 
response to an IRQ input. When an 
interrupt is received after an ABORT 
that occurs during the WAI instruction, 
the processor returns to_tl1_g_WAI 
instruction. Other than RES (highest 
priority), ABORT is t_hir1exti1ighest 
priority, followed by NMI or IRQ inter- 
rupts. 


STP Instruction-The STP instruction 


disables the o2 clock to all circuitry. 
When disabled, the o2 clock is held in 
the high state. In this case, the Data 
Bus remains in the data transfer state 
and the Bank address is not multiplexed 
onto the Data Bus. Qpgn executing the 
STP instruction, the RES signal is the 
only input that can restart the processor. 
The processor is restarted by enabling 
the 02 clockltich occurs on the falling 
edge of the RES input. Note that the 
external oscillator must be stable and 
operating properly before Rggoes 
high. 


COP Signatures - Signatures 00-7F may 
be user defined, while signatures 80-FF 
are reserved. 


RDY Pulled During Write-The NMOS 
6502 does not stop during a write 
operation. In contrast, both the 65002 
and the VL65C816 do stop during write 
operations. 


MVN and MVP effects on the Data Bank 
Register - The MVN and MVP instruc- 
tions change the Data Bank Register to 
the value of the second byte of the 
instruction (destination bank address). 


INTERRUPTS 
Interrupt Priorities - The following 
interrupt priorities are in effect should 


DC CHARACTERISTICS: TA = o<=c to +1o<>c, voo = 5 v :l:5% 


more than one interrupt occur at the 
same time: 


RES 
Highest 
ABORT 
WI 
TITO 


TRANSFERS 
Transfers from 8-bit to 16-bit, or 16-bit 
to 8-bit, Registers - All transfers from 
one register to another result in a full 
16-bit output from the source register. 
The Destination Register size deter- 
mines the number of bits actually stored 
in the destination register and the 
values stored in the processor Status 
Register. The following are always 16- 
bit transfers, regardless of the accumu- 
lator size: 


TCS; TSC; TCD; TDC 


Stack Transfers - When in the Emula- 
tion mode, a 01 is forced into SH. In 
this case, the B Accumulator is not 
loaded into SH during a TCS instruc- 
tion. When in the Native mode, the B 
Accumulator is transfered to SH. Note 
that in both the Emulation and Native 
modes, the full 16 bits of the Stack 
Register are transferred to the A, B, and 
C Accumulators, regardless of the state 
of the M bit in the Status Register. 


Lowest 


g 
g 
Parameter 
j 
‘ 
Symbol 


_ 
kiiw 
Min 
i 
Max 
Unit 


Input High Voltage 
RES, i=io\r,_|FiQ. Data, BE. 
¢2 (IN), NMI, ABORT 


A 
if 
VIHT 
RF 


0.7 Voo 


___ 
4 
_ 
' 


2.0 
Voo + 0.3 
V 
Voo + 0.3 
. 
V 


Input Low Voltage 
RES, RDY, IRQ, Data, BE. 
¢2 (IN). NMI, ABORT 


» 
v.;r 
, 


_ 
_ 
4 
' 
7'" 
7 


-0.3 
0.8 
V 
-0.3 
0.2 
V 
Input Leakage Curr_e1t (VIN = 0 to Voo) 
RES. NW. RDY. IRQ. BE, ABORT (Internal Pullup) 
¢>2 (IN) 
___ 
W Address, Data, R/W (Off State, BE = 0) 
- 
-10 
10 


|IN 
-100 
1 
pA 
-1 
1 
pA 


I 
uA 
Output High Voltage (log: ;1£0uA) 
Data, Address, R/W, ML, VP, M/X, E, VDA, VPA, 
¢2 (OUT) 


VOH 


l 


_ 
w 
' 


0.7 Voo 
— 
V 


Output Low Voltage (I0£_§_1_.§_mAl 
A 
Data, Address, Ft/V7, MI__,_VP, M/X, E. VDA, VPA, 
¢2 (our) 


VOL 


—— 
0.4 
V 
Supply Current (No Load) 
AW 
1 
loo 
Standby Current (No Load. Data Bus =Vss or Voo 
Ise 
i 
RES, NMI, IRQ. BE, ABORT, ¢2 = VDD) 


l 
,, 
it 
H” ,_ 
Capacitance (VIN = 0V, TA = 25° C, f = 2 MHz) 
Logic, ¢2 (IN) 
__ 
Cm 
Addre_ss,Data, R/W (Off State) 
i 
_ 
g 
g_C*Ts 
— 
15 
‘ 
pF 
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4 
i W”.mA/MHZ 


10 
pA 
i 
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ABSOLUTE MAXIMUM RATINGS 
Ambient Operating 
Stresses above those listed under 
Temperature 
0°C to +70°C 
"Absolute Maximum Ratings” may cause 
Storage Temperature 
_55,,C to H5006 
permanent damage to the device. These 
are stress ratings only. Functional 
SUPIJIY V°|la99 to 
operation of this device under these or 
Ground Potential 
-0-3 V t0 +7-0 V 
any conditions other than those indi- 
cated in this data sheet is not implied. 
Applied Input 
Exposure to absolute maximum rating 
Voltage 
-0.3 V to VDD+ 0.3 V 
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conditions for extended periods may 
affect device reliability. 
This device contains input protection 
against damage due to high static 
voltages or electric fields. However, 
precautions should be taken to avoid 
application of voltages higher than the 
maximum rating. 
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FEATURES 


~ 
Address mark detection circuitry 
' 
Software control of 
—Track stepping rate 
—Head load time 
—Head unload time 


~ 
IBM compatible in both single- and double-density format 


~ 
Programmable data record lengths: 128, 256,512, 1024, 2048, 
4096 or 8192 bytes/sector 


~ 
Multi-sector and multi-track transfer capability 


~ 
Controls up to four floppy disk drives 


~ 
Data scan capability-will scan a single sector or an entire 
track of data fields, comparing on a byte-by-byte basis data 
in the processor's memory with data read from the disk 


~ 
Data transfers in DMA or non-DMA mode 


~ 
Parallel seek operations on up to four drives 


~ 
Directly compatible with an 8-bit or 16-bit synchronous 
microprocessor bus including Z-80/8080Al8085A, 
8086, and 8088 
' 
Replaces the NEC p.PD765A, Intel 8272A, and 
Rockwell 6765A 


~ 
Single phase 4 or 8 MHz clock 


~ 
Single +5 volt power supply 
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DOUBLE-DENSITY FLOPPY 
DISK CONTROLLER (DDFDC) 


DESCRIPTION 
The VL6765 Double-Density Floppy Disk Controller (DDFDC) 
interfaces up to four floppy disk drives to an 8-bit or 16-bit 
microprocessor-based system including Z80, 8080A, 8085A, 8086, 
and 8088. The DDFDC simplifies the system design by minimiz- 
ing both the number of external hardware components and soft- 
ware steps needed to implement the floppy disk drive (FDD) 
interface. Control signals supplied by the DDFDC reduce the 
number of components required in external phase locked loop 
and write precompensation circuitry. Memory-mapped registers 
containing commands, status and data simplify the software inter- 
face. Bullt-in functions reduce the software overhead needed to 
control the FDD interface. The DDFDC supports both the 
IBM 3740 Single-Density (FM) and IBM System 34 Double-Density 
(MFM) formats. 


The DDFDC interfaces directly to the synchronous microproces- 
sor bus and operates with 8-bit byte length data transferred on 
the bus in either DMA or non-DMA mode. In DMA mode, the CPU 
need only load the command into the DDFDC and all data 
transfers occur under DMA control. The.VL6765 is directly com- 
patible with the Z8410/;iPD8257 Direct Memory Access Controller 
(DMAC). In non-DMA mode, the DDFDC generates an interrupt 
to the CPU indicating that a byte of data is available. 


PIN DIAGRAM 
VL6765 
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ORDER INFORMATION 
Part 
I 
Clock 
I 
I 
Number 
W 
f 
Frequency 
Package 
vi_e7es-o4Pc 
Plastic DIP 
VL6765-04CC 
, 
4 MHz 
Ceramic DIP 


‘ 
Plastic Leaded 
VL6765-04QC 


W 
_ 
__ 
Chip Carrier (PLCC) 
Plastic DIP 
8 MHz 
Ceramic DIP 
Plastic Leaded 
Chip Carrier (PLCC) 


VL6765-08PC 
VL6765-OBCC 
VL6765-08QC 


Note: 
Operating temperature range: 0°C to +70°C. 
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PIN DIAGRAM 


8 


D1 


UN 
oa 
o4 
os 
D6 
01 
ono 
T:Ti'6<' 
TC 


VL6765 
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___ 
___ 
SEEK STP 
CS 
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We 
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HDL 


(DI 
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I 
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CLK 
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39 


38 
37 


10 
36 


11 
35 


12 
34 


13 
33 


14 
32 


15 
31 


16 
30 


17 
29 


RDY 
WP/TS 


FLT/TRKO 


PSO 


PS1 
WDA 


USO 


US1 


HD 


MFM 
WE 
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Figure 1. 
DDFDC Input and Output Signals 
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Es 
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INT 
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W 


DACK 


DMAC 
TC 
INTERFACE 
DRQ 


CLK 


vcc 


GNDl 


PIN DESCRIPTION 


Throughout this document signals are presented using the terms 
active and inactive, or asserted and negated, independent of 
whether the signal is active in the high-voltage state or low-voltage 
state. (The active state of each logic pin is described below.) Active 
low signals are denoted by a superscript bar. 


BUS INTERFACE 


D0-D7-Data Llnes. The bidirectional data lines transfer data 
between the DDFDC and the 8-bit data bus. 


CLK—CLOCK. The clock is a ‘ITL compatible 4 or 8 MHz square 
wave signal. 


RST—RESET. This active high input places the DDFDC in the 
idle state and resets the output lines to the floppy disk drive (FDD) 
to the low state. RST does not affect the Step Rate Time (SRT), 
Head Unload Time (HUT) or Head Load Time (HLT) set by a 
Specify command. If RDY goes high while RST is high, the 
DDFDC will assert INT within 1.024 ms. This interrupt can be 
cleared by issuing a Sense Interrupt Status command. 


FS—Chlp Select. The DDFDC is selected when the ‘(E input 
is low. 


A0—Data/Status Register Select. This input selects the Data 
or Status Register for reading from or writing to. when A0 = high, 
the Data Register is selected_and the state of Rim WR 
determines whether it isa read (RD = low) orawrite(WR = low) 
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RDW 


RDD 


VCO 


WCK 
FDO 
SERIAL 
WDA 
DATA 
WE 
INTERFACE 


PSO-PS1I 
RDY 


IDX 


WP/TS 


FLT/TRKO 


LCT/DIR 


FRISTP 
ihseek 
FDD 
CONTROL/STATUS 
“DL 
INTERFACE 
no 


USO 


US1 


MFM 


operation. When A0 = low, th_e Status Register is scted. This 
register may only be read (RD = low); the state WR = low is 
invalid when the Status Register is selected. 


lNT—lnterrupt Request. This active high output is the interrupt 
request generated by the DDFDC to the CPU. INT is asserted upon 
completion of some DDFDC commands and before a data byte 
is transferred between the DDFDC and the data bus (in the Non- 
DMA mode). 


'I—Read. This active low input defines the data bus transfer 
as a read cycle. When low, the data transfer is from the DDFDC 
to the data bus. 


S 
WR—Write. This active low input defines the data bus transfer 
as a write cycle. When low, the data transfer is from the data bus 
to the DDFDC. 


DIRECT MEMORY ACCESS CONTROLLER 
(DMAC) INTERFACE 


DACK—DIVlA Acknowledge. The DMA transfer acknowledge 
signal is a Tl'L compatible input generated by the DMA controller 
(DMAC) controlling the DDFDC. The DMA cycle is active when 
DACK is low and the DDFDC is performing a DMA transfer. 


DRO—Data DMA Request. The transfer request signal is a TIL 
compatible output generated by the DDFDC to request a data 
transfer operation under control of the DMAC (in the DMA mode). 
The request is active when DRO = high. The signal is reset 
inactive when DMA Acknowledge (DACK) is asserted (low). 
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TC—TerminaI Count. This input signal is issued to the DDFDC 
when the DMA transfer for a channel is complete. The signal is 
active high concurrent with the DACK input when the DMA 
operation is complete as a result of that transfer. 


FDD SERIAL DATA INTERFACE 


RDD—Read Data. Read Data input from the floppy disk drive 
(FDD) containing clock and data bits. 


RDW-Read Data Window. Data Window input generated by the 
Phase Locked Loop (PLL) and used to sample data from the FDD. 


VCO—Voltage Controlled Oscillator Sync. This output signal 
inhibits the VCO in the PLL circuit when low and enables the 
VCO in the PLL circuit when high. This inhibits RDD and RDW 
from being generated until valid data is detected from the FDD. 


WCK—Write Clock. This input clock determines the Write Data 
rate to the FDD. The data rate is 500 KHz in the FM mode (MFM 
= low) and 1 MHz in the MFM mode (MFM = high). The pulse 
width is 250 ns (typical) in both modes. 


WDA-Write Data. Serial write data output to the FDD contain- 
ing both clock and data bits. 


WE—Write Enable. This output signal enables the Write Data 
into the FDD when high. 


PSO-PS1—Preshift. These outputs are encoded to convey write 
compensation status during the MFM mode to determine early, 
late or normal times as follows: 


I 
Preshlft Outputs 
Write Precom ensation Status 
so 
p 
P 
P 


Normal 
‘ 
Late 
Early 
\ 
invalid 


0 = Low,1 = High 


--00 
_A@_5@ 


FDD STATUS INTERFACE 


RDY—Ready. An active high input signal indicates the FDD is 
ready to send data to, or receive data from, the DDFDC. 


IDX—Index. An active high input signal from the FDD indicates 
the index hole is under the index sensor. Index is used to syn- 
chronize DDFDC timing. 


Wv/seek-need Write/Seek. Mode selection signal to the FDD 
which c_c>r1trols the multiplexer from the multiplexed signals. 
WhenR_W/SEEK is low, the Read/Write mode is commanded; 
when RW/SEEK is high, the Seek mode is commanded. 


RWISEEK 
Mode 
Active FOO Interface Signals 
Low 
Read/Write) 
WP, FLT, LCT, FR 
High 
Seek 
g 
TS, TRKO, DIR, STP 
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WP/TS-Write Protect/Two Side. An active high multiplexed 
input signal from the FDD. In the Read/Write mode, WP/TS high 
indicates the media is write-protected. In the Seek mode, WP/TS 
high indicates the media is two-sided. 


FLT/TRKO—Fault/Track Zero. An active high_rnultiplexed input 
from the FDD. In the Read/Write mode (RWISEEK 
=. low), 
FLT/TRKO high indicates an FDD fault. In the Seek mode, 
FLT/TRKO high indicates that the read/write head is positioned 
over track zero. 
" 


LCT/DlR—Low Current/Direction. A multiplexed output to the 
FDD. In the Read/Write mode, LCT/DIR is low when the read/write 
head is to be positioned over the inner tracks and the LCT/DIR 
is high when the head is to be positioned over the outer tracks. 
In the Seek mode, LCT/DIR controls the head direction. When 
LCT/DIR is high, the head steps to the outside of the disk; when 
LCT/DIR is low, the head steps to the inside of the disk. 


FR/STP—FauIt Reset/Step. A multiplexed output to the FDD. 
In the Read/Write mode, FR/STP high resets the fault indicator 
in the FDD. An FR pulse is issued at the beginning of each read 
or write command prior to issuing HDL. In the Seek mode, 
FR/STP provides the step pulses to move the read/write head 
to another track in the direction indicated by the LCT/DIR signal. 


HDL—Head Load. An active high output to notify the FDD that 
the read/write head should be loaded (placed in contact with the 
media). A low level indicates the head should be unloaded. 


Figure 2. 
Typical VL6765 Application 
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HD—Head Select. An output to the FDD to select the proper 
read/write head. Head One is selected when HD = high and Head 
Zero is selected when HD = low. 


USO-US1—Unit Select. Output signals for floppy disk drive selec- 
tion as follows: 


Um‘ sf°'°°‘ 
Floppy Disk 
U50 
U51 
, 
Drlve Select 


-+-eoo 
-0-0 
core--o 


0 = Low, 1 = High 


MFlVl—MFM Mode. Output signal to the FDD to indicate MFM 
or FM mode. Selects the MFM mode when MFM = high and the 
FM mode MFM = Low. 


VCC—Power. +5 Vdc. 


GND-Ground (V88). 


Figure 3. 
DDFDC Block Diagram 
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DDFDC REGISTERS 


The DDFDC contains six registers which may be accessed by 
the processor or DMA controller via the system (i.e., micro- 
processor) bus: a Main Status Register, a Data Register, and four 
Result Status Registers. The 8-bit Main Status Register (MSR) 
contains the status information of the DDFDC, and may.be 
accessed at any time. The 8-bit Data Register, consisting of 
several registers in a stack with only one register presented to 
the data bus at a time, stores data, commands, parameters and 
FDD status information. Bytes of data are read out of, or written 
into, the Data Register in order to initiate a command or to obtain 
the results of a command execution. 


The read-only Main Status Register facilitates the transfer of data 
between the system and the DDFDC. The other Status Registers 
(STO, ST1, ST2 and ST3) are only available during the result 
phase, and may be read only after completing a command. The 
particular command which has been executed determines how 
many of the Status Registers will be read. 
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°°"TR°" 
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HDL 
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S 
Ere relationship between the status/data registers and the WR, 
RD and A0 signals is shown below. 


RD 
WR 
I 
Function 


; 
Illegal 
Read Main Status Register 
Illegal 
Illegal 


( 
Read from Data Register 
Write into Data Register 
---iooo8 
-00-ioo 
o-oo-so 


0 =iLow,1 = High 


Table 1 shows each of the status registers used by the DDFDC 
and each bit assignment within the individual registers. Table 2 
defines the symbols used throughout the command definitions. 
Each register bit symbol is defined in the register descriptions that 
follow Table 2. 


REGISTER DEFINITIONS 


Main Status Register (MSR) 


DIO 
EXM 
D2B 
D18 
OB 


The Main Status Register (MSR) contains the status information 
of the DDFDC, and must be read by the processor before each 
byte is written to, or read from, the Data Register during the com- 
mand or result phase. MSR reads are not required during the 
execution phase. The Data Input/Output (DIO) and Request for 
Master (ROM) bits in the MSR indicate when data is ready and 
in which direction data will be tranrred on the data bus. The 
maximum time between the last RD or WR during command 
or result phases and the DIO and ROM getting set or reset is 
12 p.S. For this reason, every time the MSR is read the processor 
should wait 12 p.S. The maximum time from the trailing edge of 
the last RD in the result phase to when bit 4 (DDFDC Busy) 
goes low is also 12 p.S. 


The DIO and ROM timing chart is shown in Figure 4. 


3 


~10: 
:n 
ROM 
-Request for Master. 
Data Register is not ready. 
Data Register is ready. 
--0 


Z 


-ocnm 


I 
DIO 
—Data Input/Output. 
Data transfer is from system to the Data Register. 
Data transfer is from Data Register to the system. 


3 


ouim 


I 
EXM 
-Execution Mode. (Non-DMA mode only). 
Execution phase ended, result phase begun. 
Execution phase started. 


i 


—L 


Z 


-0:-m 


I 
_ 
CB 
—ControlIer (DDFDC) Busy. 
DDFDC is not busy, will accept a command. 
DDFDC is busy, will not accept a command. 


MSR 
§_ 
D38 
—Floppy Disk Drive (FDD) 3 Busy. 
0 
FDD 3 is not busy, DDFDC will accept read or write 
command. 


1 
FDD 3 is busy, DDFDC will not accept read or write 
command. 


MSR 
g 
D28 
—FDD 2 Busy. 
0 
FDD 2 is not busy, DDFDC will accept read or write 
command. 


1 
FDD 2 is busy, DDFDC will not accept read or write 
command. 


MSR 
1 
D18 
—FDD 1 Busy. 
0 
FDD 1 is not busy, DDFDC will accept read or write 
command. 


1 
FDD 1 is busy, DDFDC will not accept read or write 
command. 


MSR 
Q 
DOB 
-FDD 0 Busy. 
0 
FDD 0 is not busy, DDFDC will accept read or write 
command. 


1 
FDD 0 is busy, DDFDC will not accept read or write 
command. 


Status Register 0 (STO) 


7- 
I 
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W42“ 
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It Us 
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EC 
NR 
HD 
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The Status Register 0 (STO) as well as the other status registers 
(ST1-ST3), are available only during the result phase, and may 
be read only after completing a command. The particular com- 
mand executed determines which status registers are used and 
may be read. 


STO 
Z 
§ 
IC 
—Interrupt Code. 
0 
0 
Normal Termination (NT). Command was properly exe- 
cuted and completed. 
Abnormal Termination (AT). Command execution was 
started, but was not successfully completed. 
' 
1 
0 
Invalid Command (IC). Received command was invalid. 
1 
1 
Abnormal Termination (AT). The Ready (RDY) signal 
from 
the 
FDD changed 
state during 
command 
execuon. 


O 
1 


U) 


—*OUI—| 


O 
SE 
-Seek End. 
Seek command is not completed. 
Seek command completed by DDFDC. 


(D 


-5-I 


O 
EC 
-Equipment Check. 
No error. 
Either a fault signal is received from the FDD or the track 
0 signal failed to occur after 256 step pulses (Recalibrate 
command). 


-o 
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Table 1. 


Main Status Register (MSR) 
7 
5 
5 
4 
3 


Status Register 0 (STO) 
-A 
as 
A 
- 
. 
e 
- 


IC 
SE 
I 
EC 
Status Register 1 (ST1) 
l 


_ 
__ 
_ 
_ 
___ 
____ 
___ 
) 
Status Register 2 (ST2) 
EN 
0 
DE 
‘ 
on 


Status Register 3 (ST3) 
0 
CM 
DD 
WT 


DDFDC Status Register Bit Assignments 


Bit Number 


, 
2 
1 
O 
ROM 
I 
“Polo 
EXM 
ca 
' 
oae 
B 
02s 
D1B 
ooe 


_,_,, 
. 
NR 
HD 
i 
_ 
7. 
____ 
__ 
___ 
__<-_ 
US1 
uso 
B 


ND 
NW 
MA 
O 


I 
I 
I 
SH 
I 
SN 
BT 
MD 


_ 
Tr’ 
_ 
_ 
_ 
k 
cc’ 
1* 
’"'**~~* 
W 
_ 
17cc" 
*7 
T 
Tr 
" 
r 
_ 
_ 
FLT 
BWP 
RDY 
TRKO 
B 
TS 
HD 
Bust 
uso 


Table 2. 
Command Symbol Description 


Symbol 
T 
Name 
If 
If 
Descrlptlon 
I 
A0 
B 
Address Line 
B 
, 
Controls selection oBlBBMain Status Register (A0 
-B—B low)_orBData Register (A0 = high). 
B 


D 
I 
Data 
I 
B BB 
BB 
The data pattern which is going to be written into a sector. 
I 
B 
O 
7 
W97 
I 
Data*BusF 
B 
H8-bit data busB,B_wBhere DO is the least significant data line FandTD7 is the mostsignificantdata line. 


PT? . 
I 
DataLength 
When N is defined as 00, DTL isthe number of data bytes to read fremBorBwrite into the sector. 


EOT 


I 
__ 
___ 
" 
' 
1 
. 
End of Track 
1 
The final sector numberion a track. During read orwrite operation, the DDFDCstopsTdata transfer 


B 
BB 
after reading from or writing to the sector equal to EOT. 
B 
GPLT 
Gap-Length 
The length of Gap 3. During Tread/write commands this value determines the number of bytes that the 


; 
VCO will stay low after two CRC bytes. During the Format a Track command it determines the size of 
Gap 3. 


Head Address 
Head numberl) or 1, as specified inlD field. 
I 
B 
If 
B 
BB 
HD (H) 
I 
Head 
B 
B 
A selected head numberBB0 or 1 which controls the polarity of pin 27. (H = HD inall command words). 


HLT 
Head Load Time 
The head load time in the FDD (2 to 254 ms in 2 ms increments).BB 
B 
BB 
B 
BB 
HUT 


E 
..._._ 
"i 


\ 
Head Unload Time 
l, 
The head unload time after aBBread or write operation has occurred (16 to 240 ms in 16 ms increments). 


MF 


I 
is 
~ 
. 
H 
1 
FM or MFM Mode 
When MF = 0,*FM mode is selected; and when MF 
== 1, MFM mode is selected. 
MT 


__-_____ 
___i 
____ 
2 


, 
Multi-Track 
, 
When MT = 1, a multi-track operation is to be performed. After finishing a read/write operation on side 
0, the DDFDC will automatically start searching for sector 1 on side 1. 


N 
Bytes/Sector BB 
The numbeBrBBofB data bytes written in a sector. 
B 
B 
B 
B 
BB 
B 


ND 
I 
Non-DMA Mode 
When ND = 1, operation is in the Non-DMA mode; when ND = 0, operation is in the DMA mode. 


NTN 
New Track Number 
A new track number, which will be reached as a result of the Seek command. Desired head position. 
PTN 


*7 
'* 
_ 
____ 
T 
I 


I 
Present Track Number 
The track number at the completion of Sense Interrupt Status command. Present head position. 


Record (Sector) 
3 
The sector number to be read or written. 
B 


R/W 
Either read (R) or write (W) signal. 
J Read/Write 
1 
B 
B 
ST 
B 


,,__ 
ll 
. 
Sectors/Track 
Theniumber of eectors per track. 
B 
B 
B 
B 
SK 
BB 


'7' 
I 


I 
Skip T 
T 
I 
Skip Deleted Data Address Mark. 


SRT 


I 
7 
7 
_-7 
e__ 
O 
7 
777 
7 
7 
— 
— 
Step Rate Time 
; 
The stepping rate for the FDD (1 to 16 ms in 1 ms increments). Stepping rate applies to all drives 


, 
(F = 
1 ms, E = 2 ms, etc.) 


STO 
ST1 
ST2 
ST3 


_ 
I 
i 
_ 
_ 
____ 
__ 
__ 
77 
Status 0 
I 
Four registers which store the status information after a command has been executed. This information 


‘ 
Status 1 
is available during the result phase after command execution. These registers should not be confused 
Status 2 
l 
with the Main Status Register (selected by A0 = low). STO-ST3 may be read only after a command has 
Status 3 
been executedand contain information relevant to that particular command. 
_B_ 


STP 
Sector Test Process 
, 
During a Scan command, if STP = 01, the data in contiguous sectors is compared byte by byte with data 


§ 
sent from the processor (or DMA controller); and if STP = 02, then alternate sectors are read and 


B 
B 
BB BB_Bcompared. 
BBB _BB 
B 
To 


B 
Track Number 
B 
B 
The current/selected track number of the medium (0-255). 


USO,US1 BB 
BBBBBUrBiitBSelect 
B 
Aselected drive number (0-3). 
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(D 


Q-I 


O 
NR 
—Not Ready. 
FDD is ready. 
FDD is not ready at issue of read or write command. If 
a read or write command is issued to side 1 of a single- 
sided drive, this bit is also set. 


-o 


U) 


--on-| 


o 
HD 
—Head Address. (At Interrupt). 
Head Select 0. 
Head Select 1. 


-A-Loo-hm 


—I 


-L@_L@Q@ 


__ 
US 
—UnIt Selected. (At Interrupt). 
FDD 0 selected. 
FDD 1 selected. 
FDD 2 selected. 
FDD 3 selected. 


Status Register 1 (ST1) 


(D 


-50%: 


EN 
—End of Track. 
No error. 
DDFDC attempted to access a sector beyond the last 
sector of a track. 


ST1 
§ 
—Not Used. Always Zero. 


U) 


U1-I 


-IL 
DE 
-Data Error. 
No error. 
DDFDC detected a CRC error in ID field or the Data field. 
-o 


U) 


4*-I 


ql 
OR 
—Overrun. 
No error. 
DDFDC was not serviced by the system during data 
transfers, within a predetermined time interval. 


-so 


ST1 
3 
—Not Used. Always Zero. 


(D 


—*Ol\J—~| 


-5 
ND 
-No Data. 
No error. 
.3 possible errors. 


1. DDFDC cannot nd sector specied in the Internal Data 
Register (IDR) during execution of Read Data, Write 
Deleted Data or Scan commands.- 


2. DDFDC cannot read ID field without an error during 
Read ID command. 


3. DDFDC cannot find starting sector during execution 
of Read a Track command. 
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(D 
*1 NW 
—Not Wrltable. 
No error. 
DDFDC detected a write protect signal from FDD during 
execution of Write Data, Write Deleted Data or Format 
a Track commands. 


-o 


U) 


-‘CO: 


MA 
—MIsslng Address Mark. 
No error. 
2 possible errors. 


1. DDFDC cannot detect the ID Address Mark after 
encountering the index hole twice. 


2. DDFDC cannot detect the Data Address Mark or 
Deleted Data Address Mark. The MD (Missing Address 
Mark in Data field) of Status Register 2 is also set. 


Status Register 2 (ST2) 


W 
s 
5 
4 
3 
2 
1 
Io“ 
I-I I 
6 
I 
-52 I 
4 
I 
.3 ‘" I 
2 
I 
I I 
0 
I 


_,, 
_ 
__ 
___ 
_ 
~ 
— 
— 
~— 
D 
EN 
0 
DE 
on 
0 
ND 
NW 
MA 
0 
. 
CM 
DD..wT 
SH 
. 
SN 
BT 
M 


ST2 
Z 
—Not Used. Always Zero. 


(D 


—-KOO!-~| 


M 
CM 
—Control Mark. 
No error. 
DDFDC encountered a sector which contained a Deleted 
Data Address Mark during execution of a Read Data, 
Read a Track, or Scan command,or which contained a 
Data Address Mark during execution of a Read Deleted 
Data command. 


i 


U) 


U1-I 


N 
DD 
—Data Error In Data Fleld. 
No error. 
DDFDC detected a CRC error in the Data field. 
-so 


(D 


—*C)b—| 


N 
_ 
WT 
-Wrong Track. 
No error. 
Contents of T on the disk is different from that stored in 
IDR. Bit is related to ND (Bit 2) of Status Register 1. 


(D 


99-1 


N 
SH 
-Scan Equal Hlt. 
No “equal" condition during a scan command. 
“EquaI" condition satisfied during a scan command. 
-o 


(D 


N-I 


IO 
SN 
-Scan Not Satisfied. 
No error. 
DDFDC cannot find a sector on the track which meets 
the scan command condition. 


-so 
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in 


-*—l 


IO 
BT 
—Bad Track. 
No error. 
Contents of T on the disk is different from that stored in 
the IDR and T = FF. Bit is related to ND (Bit 2) of Status 
Register 1. 


-o 


(D 


O-I 


IO 
MD 
—Misslng Address Mark in Data Field. 
No error. 
DDFDC cannot find a Data Address Mark or Deleted Data 
Address Mark during a data read from the disk. 


-o 


Status Register 3 (ST3) 


T 
WP 
RDY 
TRKO 
TS 
HD 
US1 
USO 


Status Register 3 (ST3) holds the results of the Sense Drive Status 
command. 


U) 


—*OQ—l 


(J 
FLT 
—FauIt. 
Fault (FLT) signal from the FDD is low. 
Fault (FLT) signal from the FDD is high. 


U) 


59-1 


Cd 
WP 
—Write Protect. 
Write Protect (WP) signal from the FDD is low. 
Write Protect (WP) signal from the FDD is high. 
-so 


(D 


U1-I 


Cd 
RDY 
—Ready. 
Ready (RDY) signal from the FDD is low. 
Ready (RDY) signal from the FDD is high. 
-o 


(D 


J5-I 


(0 
TRKO 
—Track 0. 
Track 0 (TRKO) signal from the FDD is low. 
Track 0 (TRKO) signal is from the FDD is high. 


U) 


03-1 
—*Q 


(ill 
TS 
—Two Slde. 
Two Side (TS) signal from the FDD is low. 
Two Side (TS) signal from the FDD is high. 


In 


-eon-1 
-eo 


no 
ICI 
—Head Select. 
Head Select (HD) signal to the FDD is low. 
Head Select (HD) signal to the FDD is high. 


ST3 


_,|,@¢g,,|-s@-A 


Q 


US1 
—Unit Select 1. 
Unit Select 1 (US1) signal to the FDD is low. 
Unit Select 1 (US1) signal to the FDD is high. 


USO 
—Unit Select 0. 
Unit Select 0 (USO) signal to the FDD is low. 
Unit Select 0 (US1) signal to the FDD is high. 
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COMMAND SEQUENCE 


The DDFDC is capable of performing 15 different commands. 
Each command is initiated by a multi-byte transfer of data from 
the system. After command execution, the result of the command 
may be a multi-byte transfer of data back to the system. Because 
of this multi-byte transfer of information between the DDFDC and 
the system, each command consists of three phases: 


Command Phase—The DDFDC receives all information 
required to perform a particular operation from the system. 


Execution 
Phase—The DDFDC performs the instructed 
operation. 


Result Phase—After completion of the operation, status and 
other housekeeping information are made available to the system. 


The bytes of data sent to the DDFDC to form a command, and 
read out of the DDFDC in the result phase, must occur in the 
order shown for each command sequence. That is, the command 
code byte must be sent first followed by the other bytes in the 
specified sequence. All command bytes must be written and all 
result bytes must be read in each phase. After the last byte of 
data in the command phase is received by the DDFDC, the execu- 
tion phase starts. Similarly, when the last byte of data is read out 
in the result phase, the command is ended and the DDFDC is 
ready to accept a new command. A command can be terminated 
by asserting the Terminal Count (TC) signal to the DDFDC. This 
ensures that the processor can always get the DDFDC's atten- 
tion even if the command in process hangs up in an abnormal 
manner. 
COMMAND DESCRIPTION 


READ DATA 


A command set of nine bytes places the DDFDC into the Read 
Data mode. After the Read Data command has been received 
the DDFDC loads the head (if it is unloaded), waits the specified 
Head Settling Time (defined in the Specify command), then begins 
reading ID Address Marks and ID fields from the disk. When the 
current sector number (R) stored in the ID Register (IDR) matches 
the sector number read from the disk, the DDFDC transfers data 
from the disk Data field to the data bus. 


After completion of the read operation from the current sector, 
the DDFDC increments the Sector Number (R) by one, and the 
data from the next sector is read and output to the data bus. This 
continuous read function is called a “Multi-Sector Read Opera- 
tion." The Read Command terminates after reading the last data 
byte from sector R when R = EOT. STO bits 7 and 6 are set to 
0 and 1, respectively, and ST1 bit 7 (EN) is set to a 1. 


The Read Data command can also be terminated by a high 
Terminal Count (IC) signal. TC should be issued at the same 
time thatthe DACK for the last byte of data is sent. Upon receipt 
of TC, the DDFDC stops outputting data to the data bus, but con- 
tinues to read data from the current sector, checks CRC (Cyclic 
Redundancy Count) bytes, and then at the end of that sector ter- 
minates the Read Data command and sets bits 7 and 6 in STO 
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to 0. The amount of data which can be handled with a single com- 
mand to the DDFDC depends upon MT (Multi-Track), MF 
(MFM/FM), and N (Number of Bytes/Sector) values. Table 3 shows 
the transfer capacity. 


The multi-track function (MT) allows the DDFDC to read data from 
both sides of the disk. For a particular track, data is transferred 
starting at sector 1, side 0 and completed at sector L, side 1 
(sector L = last sector on the side). This function pertains to only 
one track (the same track) on each side of the disk. 


WhenN = 0 in command byte 6 (FM mode), the Data Length 
(DTL) in command byte 9 defines the data length that the DDFDC 
must treat as a sector. If DTL is smaller than the actual data 
length in a sector, the data beyond the DTL is not sent to the 
data bus. The DDFDC reads (internally) the complete sector, per- 
forms the CRC check, and depending upon the manner of com- 
mand termination, may perform a multi-sector Read operation. 
When N is non-zero (MFM mode), DTL has no meaning and 
should be set to FF. 


At the completion of the Read Data command, the head is not 
unloaded until the Head Unload Time (HUT) interval defined in 
the Specify command has elapsed. The head settling time may 
be avoided between subsequent reads if the processor issues 
another command before the head unloads. This time savings 
is considerable when disk contents are copied from one drive to 
another. 


If the DDFDC detects the Index Hole twice in succession without 
finding the right sector (indicated in R), then the DDFDC sets the 
No Data (ND) flag in Status Register 1 (ST1) to a 1, sets Status 
Register 0 (STO) bits 7 and 6 to 0 and 1, respectively, and ter- 
minates the Read Data command. 


After reading the ID and Data fields in each sector, the DDFDC 
checks the CRC bytes. If a read error is detected (incorrect CRC 
in ID field), the DDFDC sets the Data Error (DE) flag in ST1 to 
a 1, sets the Data Error in Data Field (DD) flag in ST2 to a 1 if 
a CRC error occurs in the Data field, sets bits 7 and 6 in STO 
to 0 and 1, respectively, and terminates the command. 


Table 3. 
DDFDC Transfer Capacity 
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If the DDFDC reads a Deleted Data Address Mark from the disk, 
and the Skip Deleted Data Address Mark bit in the first command 
byte is not set (SK = 0), then the DDFDC reads all the data in 
the sector, sets the Control Mark (CM) flag in ST2 to a 1, and 
terminates the command. If SK = 1, the DDFDC skips the sec- 
tor with the Deleted Data Address Mark and reads the next sec- 
tor. The CRC bits in the deleted data field are not checked when 
SK = 1. 


During disk data transfers from the DDFDC to the system, the 
DDFDC must be serviced by the system within 27 as in the FM 
mode, and within 13 as in the MFM mode, otherwise the DDFDC 
sets the Over Run (OR) flag in ST1 to a 1, sets bits 7 and 6 in 
STO to 0 and 1, respectively, and terminates the command. 


If the processor terminates a read (or write) operation in the 
DDFDC, then the ID information in the result phase is dependent 
upon the state of the .’.lT bit in the first command byte and the 
End of Track (EOT) byte. Table 4 shows the values for Track 
Number (T), Head Number (H), Sector Number (R), and Number 
of Data Bytes/Sector (N), when the processor terminates the 
command. 


Command Phase: 


If 
R/W 
BYTEI7 
s 
s 
4 
3 
10 
w 
1 
MT 
MF SK001 
1 
0 


It 
' 
" 
' 
T’ 
' 
' 
' 
_ 
____ 
2x 
XXXXHDUS1USO 


3 
Track Number (T) 


r 
r 
~ 
s 
1 
"5 
4 
* 
Head Number (H) 


5 
Sector Number (R) 


6 
Number of Data Bytes per Sector (N) 


7 
I 
End of Track (EOT) 


8 
Gap Length (GPL) 
9 
. 
Data Length (DTL) 


Multi-Track 
MFMIFM 
I 
Bytes/Sector 
(MT) 
(MF) 
(N) 
Maximum Transfer Capacity 
Final Sector Read 
(Bytes/Sector) (Number of Sectors) 
B 
from Disk 


O 
O 
00 


O 
1 
01 
(128) (26) 
(256) (26) 
s,s2e 
K I 
. 
I 
6,656 
26 at Side 0 
or 26 at Side 1 


H 
...;@ 
O0 
01 
B 
(128) (52) 
(256) (52) 
6,656 
I 
13,312 
26 at Side 1 


01 
‘ 
02 
oo 
-o 
(256) (15) 
(512) (15) 
s,e4o 
. 
1.seo 


——— 
I 
7-I--7 
Yli 
15 at Side 0 
or 15 at Side 1 


01 


I 
02 
H 
-so 
(256) (30) 
(512) (30) 


I 
I 
7,680 
15.360 
15 at Side 1 
FFT 
I 
02 
03 
oo 
-o 
(512) (8) 
(1024) (8) 


--— 
' 
I 
4.096 
8,192 
8 at Side 0 
or 8 at Side 1 


H 
-50 
O2 
03 
(512) (16) 
(1024) (16) 
8,192 
16,384 
8 at Side 1 
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Table 4. 
DDFDC Command Termination Values 
VL6765 


COI'l1l11f1dC ph8S6 |D 
KC 
I 
U H 
Mum: 
I 
Headi 
Final Sector Transferred 
1-rack 
Numb“ 
to/from Data Bus 


g (MT) 
(HD) 


L 
g 
Result Phase ID 
_ 


Track 
Head 
C 
Sector 
‘ 
No. of 
Number 
Number 
Number 
Data Bytes 
E 
(T) 
W 
(H) 
(B) _ 
(N) 
__ 
I 
_ 
, 
**** E’ 
_ 
— 
O 
Less than EOT 
‘ 
NC 
NC 
CCR+1 
NC 


T 
K 
0 
K 
Equal to EOT 


_ 
_ 
_, 
‘ 
, 
T + 
1 
NC 
01 
NC 


0 
A 
1 
I 
Less than EOT 


Ié 
E’ 
___ 
E 
__ 
4 
__ 
' 
ms 
NC 
NC 
R + 
1 
NC 


I 
1 I I 
‘ 
Equal to EOT 
T + 
1 
NC 
01 
NC 


O 
Less than EOT 
NC 
NC 
R + 
1 
NC 


O 
‘ 
Equal to EOT 


____ 
__ 
__ 
__ 
1, 
_ 
_ 
__ 
NC 
LSB 
01 
NC 


1 
1 
Less than EOT 
NC 
NC 
R + 
1 
NC 


1 
Equal to EOT 


T 
' 
__ 
' 
* 
*1 
__ 
T + 
1 
|.se 
01 
A 
NC 


_ 
_ 
_7A 
_ 
___ 
L 
__ 
_ 
__ 
7 
i 
_ 
W 
‘L 
N 
_ 
f 
_ 
_ 


NOt8SI 
W 
C 
1. NC (No Change): The same value as the one at the beginning of command execution. 
2. LSB (Least Significant Bit): The least significant bit of H is complemented. 


Result Phase: 
g 
_ 
g 


R 
1 
Status Register 0 (STO) 


2 
Status Register 1 (ST1) 


‘ 
3 
Status Register 2 (ST2) 


L )4 
it 
Track Number(T) 


1 
s 
‘Head Number (H) 


\ 
6 
Sector Number (R) 


7 
Number of Data Bytes per Sector (N) 


WRITE DATA 


A command set of nine bytes places the DDFDC in the Write Data 
mode. After the Write Data command has been received the 
DDFDC loads the head (if it is unloaded), waits the specified Head 
Settling Time (defined in the Specify command), then begins 
reading ID fields from the disk. When the four bytes (T, H, R, N) 
loaded during the command match the four bytes of the ID field 
from the disk, the DDFDC transfers data from the data bus to 
the disk Data field. 


After writing data into the current sector, the DDFDC increments 
the sector number (R) by one, and writes into the Data field in 
the next sector. The DDFDC continues this multi-sector write 
operation until the last byte is written to sector R when R = EOT. 
STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit 
7 (EN) is set to a 1. 


The command can also be terminated by a high on Terminal 
Count (TC). If TC is sent to the DDFDC while writing into the cur- 
rent sector, then the remainder of the Data field is filled with 00 
(zeros). In this case, STO bits 7 and 6 are set to 0 and the com— 
mand is terminated. 


The DDFDC reads the ID field of each sector and checks the CRC 
bytes. If the DDFDC detects a read error (incorrect CRC) in one 


of the ID fields, it terminates the Write Data command, sets the 
DE flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1, 
respectively. 


The Write Data command operates in much the same manner 
as the Read Data command. Refer to the Read Data command 
for the handling of the following items: 


~ Transfer Capacity 


¢ End of Track (EN) flag 


~ No Data (ND) flag 


Q Head Unload Time (HUT) interval 


~ ID information when the processor terminates command 
(see Table 4) 


Q Definition of Data Length (DTL) when N = 0 and when N ¢ 0 


In the Write Data mode, data transfers from the data bus to the 
DDFDC must occur within 27 as in the FM mode, and within 13 as 
in the MFM mode. If the time interval between data transfers is 
longer than this, then the DDFDC terminates the Write Data com- 
mand, sets the Over Run (OR) flag in ST1 to a 1, and sets bits 
7 and 6 in STO to 0 and 1, respectively. 


Command Phase: 
RIWBYTE7 
s 
s 
43 
21 
0* 
WW1MTMFO001O1 


usom 
ZAXXXXXHDUS1 


I 
3 
Track Number (T) 


, 
4 
A 
Head Number (H) 


5 
Sector Number (R) 


I- 


6 
Number of Data Bytes per Sector (N) 


I 
_ 
7 
H 
End of Track (EOT) 


g 
I 
Gap Length (GPL) 


L 
_.L_.__L_ 
,__ 
,___ 
9 
Data Length (DTL) 
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Result Phase: 
H 
U 
_ 


R 
l 
1 
L 
Status Register 0 (STO) 


2 
Status Register 1 (ST1) 


\ 
3 
, 
Status Register 2 (ST2) 


4 
Track Number (T) 
. 
are 
v 
._ 
~ 
5 
Head Number (H) 


6 
Sector Number (R) 


7 
Number of Data Bytes per Sector (N) 


WHITE DELETED DATA 


The Write Deleted Data command is the same as the Write Data 
command except a Deleted Data Address Mark is written at the 
beginning of the Data field instead of the normal Data Address 
Mark. 


Command Phase: 
g 
7 


R/W 
BYTE 
7 
6 
5 
4 
3 
2 
1 
0 


W 
1 
MT 
MF 
O 
)2 
X 
X 
X 
X 
X 
HD 
US1USO 


3 
Track Number (T) 


,_ 
i 
__ 
__ 
4 
‘ 
Head Number (H) 


-‘ 
hi 
""7" 
— 
_ 
__ 
W’ 
5 
Sector Number (R) 


6 
Number of Data Bytes per Sector (N) 


7 
End of Track (EOT) 


O 
1 
O 
O 
1 


8* 
(Gap Length (GPL) 


9 
I 
Data Length (DTL) 


Result Phase: 
_ 


R 
1 
Status Register 0 (STO) 


2 
Status Register 1 (ST1) 


3 
Status Register 2 (ST2) 


4 
Track Number (T) 


5 
Head Number (H) 


6 
jSector Number (R) 


7 
‘ 
Number of Data Bytes per Sector(N) 


READ DELETED DATA 


The Read Deleted Data command is the same as the Read Data 
command except that if SK = 0 when the DDFDC detects a Data 
Address Mark at the beginning of a Data field, it reads all the 
data in the sector and sets the CM flag in ST2 to a 1, and then 
terminates the command. If SK = 1, then the DDFDC skips the 
sector with the Data Address Mark and reads the next sector. 
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Command Phase: 


R/W 
BYTE 
7 
6 
5 
4 
3 
2 
1 
0 
w 
1 
MT 
MF 
SK 


2 
1 
X 
X 
X 
X 


3 
Track Number (T) 


4 
Head Number (H) 


0 
1 
1 
0 
0 


USO 
X) 
HD 
US1 


5 
\ 
Sector Number (R) 
__ 
g 


6 
Number of Data Bytes per Sector (N) 


7 
End of Track (EOT) 


\ 
8 
Gap Length (GPL) 


9 
Data Length (DTL) 


Result Phase: 


R 
1 
Status Register O (STO) 


2 
Status Register 1 (ST1) 


3 
Status Register 2 (ST2) 
; 
,L___, 
., 


, 
4 
Track Number (T) 


I 
" 
'7 
_ 
5 
Head Number (H) 
'_ 
_ 
_ 
i 
i 
__ 
6 
Sector Number (R) 


7 
1 
Number of Data Bytes per Sector (N) 


READ A TRACK 


The Read a Track command is similar to the Read Data com- 
mand except that this is a continuous read operation where all 
Data fields from each of the sectors on a track are read and 
transferred to the data bus. Immediately after encountering the 
Index Hole, the DDFDC starts reading the Data fields as con- 
tinuous blocks of data. This command terminates when the 
number of sectors read is equal to EOT. Multi-track operations 
are not allowed with this command. 


If the DDFDC finds an error in the ID or Data CRC check bytes, 
it continues to read data from the track. The DDFDC compares 
the ID information read from each sector with the value stored 
in the IDR, and sets the ND flag in ST1 to a 1 if there is no match. 


If the DDFDC does not find an ID Address Mark on the disk after 
it encounters the Index Hole for the second time it terminates the 
command, sets the Missing Address Mark (MA) flag in ST1 to 
a 1, and sets bits 7 and 6 of STO to 0 and 1, respectively. 
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Command Phase: 
i 
U 
J 
g 


K 
R/W 
TBYTE1 
C7 
ts 
s 
Q1 
a 
2 
m1_ 
o 
g 


K 
wi 
1 
11” to 
MF 
SK 
0 
0 
To 
1 
"Se 
x 
1 
if 


if 
. 
F 
* 
A 
es’ 
‘zxxxxt-toususog 


-1 
. 
. 
'77: 
nee 
' 
' 
ss~— 
3 
Track Number (T) 


______ 
i 
_. 
___ 
if 
_ 
__ 
__ 
4 
Li Head Number (H) 
i 
7 


1 
5 
Sector Number (R) 


.1 
_ 
~»— 
i 
_ 
_ 
' " 
1" 
e 
' 
' " 
A 
" 
6 
Number of Data Bytes per Sector (N) 


-t 
._ 
*' 
7 
— 
' 
—— 
T 
" 


\ 
7 
End of Track (EOT) 
W 
g 


‘ 
8 
Gap Length (GPL) 
g 


9 
; 
Data Length (DTL) 


Result Phase: 


R 
1 
Status Register 
(STO) 


; 
2 
Status Register 1 (ST1) 


3 
Status Register 2 (ST2) 
I 
'**" 
__I_ 
—— 
4 
\ Track Number (T), 


1 
——— 
_ 
_ 
2 
__ 
—— 


I 
5 
Head Number (H) 
‘W, 
_ 
I 
W7 
7 
—— 
—— 
__ 
_ 
Sector Number (R) 
"W 
g 
_ 


7 
Number of Data Bytes per Sector (N) 


READ ID 


The two-byte Read ID command returns the present position of 
the read/write head. The DDFDC obtains the value from the first 
ID field it is able to read, sets bits 7 and 6 in STO to 0 and ter- 
minates the command. 


lf no proper ID Address Mark is found on the disk before the Index 
Hole is encountered for the second time then the Missing Address 
Mark (MA) flag in ST1 is set to a 1, and if no data is found then 
the ND flag in ST1 is also set to a 1. Bits 7 and 6 in STO are set 
to 0 and 1, respectively and the command is terminated. 


During this command there is no data transfer between DDFDC 
and the data bus except during the result phase. 


Command Phase: 
_ 
g 
g 


if 
R/W 
A 
A BYTE? 
7 
sf 
s 
4 
all 
2 
1 
A 0 


vvi 
A 
1 
A 
0 
MF 
0 
0 
1 
0 
1 
0 
12 
x 
x 
x 
x 
x 
HD 
us) 
uso 


Result Phase: 


-If 
R 
1 
C 
Status Register0(STO) 
A 


, 
2 
Status Register 1 (ST1) 
if 


It 
no 
ad 
N 
"W """ 
s 
3 
, 
Status Register2 (ST2) 


!'7' 
le_e~_— 
4 
Track Number (T) 


TC 5 
‘Head Number (H) 


1 
I 
Sector Number (R) 
C 


A 7 
Number of Data Bytes per Sector (N) 


FORMAT A TRACK 


The six-byte Format a Track command formats an entire track. 
After the Index Hole is detected, data is written on the disk: Gaps, 
Address Marks, ID fields and Data fields; all are recorded in either 
the double-density IBM System 34 format (MF = 1) or the single- 
density IBM 3740 format (MF = 0). The particular format written 
is also controlled by the values of Number of Bytes/Sector (N), 
Sectorsffrack (ST), Gap Length (GPL) and Data Pattern (D) which 
are supplied by the processor during the command phase. The 
Data field is filled with the data pattern stored in D. 


The ID field for each sector is supplied by the processor in 
response to four data requests per sector issued by the DDFDC. 
The type of data request depends upon the Non-DMA flag (ND) 
in the Specify command. In the DMA mode (ND = 0), the DDFDC 
asserts the DMA Request (DRO) output four times per sector. 
In the Non-DMA mode (ND = 1), the DDFDC asserts Interrupt 
Request (INT) output four times per sector. 


The processor must write one data byte in response to each 
request, sending (in the consecutive order) the Track Number (1), 
Head Number (H), Sector Number (R) and Number of Bytes! 
Sector (N). This allows the disk to be formatted with non- 
sequential sector numbers, if desired. 


The processor must sendnew values for.T, H, R, and N to the 
DDFDC for each sector on the track. For sequential formatting 
R is incremented by one after each sector is formatted, thus, R 
contains the total numbers of sectors formatted when it is read 
during the result phase. This incrementing and formatting con- 
tinues for the whole track until the DDFDC, upon encountering 
the Index Hole for the second time, terminates the command and 
sets bits 7 and 6 in STO to 0. 


If the Fault (FLT) signal is high from the FDD at the end of a write 
operation, the DDFDC sets the Equipment Check (EC) flag in STO 
to a 1, sets bits 7 and 6 of STO to 0 and 1, respectively, and ter- 
minates the command. Also, a low (RDY) signal at the beginning 
of a command execution phase causes bits 7 and 6 of STO to 
be set to 0 and 1, respectively. 


Table 5 shows the relationship between N, ST, and GPL for 
various disk and sector sizes. 


Command Phase: 
g 


R/W 
LBYTEL7 
6 
5 
43 
2 
1 
0 


W 
1,0MFOO1101 
in" 
_ 
______ 
' 
7' 
___ 
""' 
2px 
x 
XXXHDUS1USO 


. 
1 
_ 
_ 
7—— 
— 
— 
—— 
— 
3 
Number of Bytes per Sector(N) 
#7 
_;7 
— — — — —— 
— 
4 
Sectors per Track (ST) 


5 
A 
Gap Length (GPL) 


. 
_,' 
—— 
6 
Data Pattern (D) 
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Table 5. 
Standard Floppy Disk Sector Size Relationship 


1 
e 
,— 
, 
,s___ 
e 
y 
. 
4 
— 


I 
No. of Data 
No. of 
L 
G3P|-°"9"1 (GPL) 
g__ 
Disk 
1 
Sector Size 
Bytes/Sector 
Sectors/Track 
Read/wme 
‘ 
Format 
Size 
Mode 
g 
B;y_t_es(Sector 
(N) 
(ST) 
W 
_mCommand1 
* 
Command? 
T 
Remarks 
g 


(FM 


128 
OO 
256 
O1 
512 
O2 
1024 
‘ 
O3 
2048 
O4 
4096 
O5 


1A 
O7 
1B 
OF 
OE 
I 
2A 
O8 
1B 
3A 
04 
A 
47 
8A 
O2 
C8 
FF- 
O1 
C8 
FF 
8!! 
p 


MFM3 


256 
01 
512 
02 
1024 
03 
2048 
04 
4096 
05 
e192 
A 
oe 


1A 
OE 
36 
OF 
1B 
54 
O8 
35 
74 
04 
99 
FF 
( 
O2 
C8 
FF 
‘ 
O1 
C8 
FF 


I 
FM 


12a 
I 
00 
12s 
00 
25s 
A 
01 
512 
o2 
1024 
oa 


g 
204a 
o4 


12 
or 
09 
10 
10 
19 
os 
1a 
so 
04 
A 
46 
er 
O2 
C8 
FF 
O1 
C8 
FF 
511" 


I 
MFM3 


256 
O1 
256 
O1 
512 
O2 
1024 
03 
2048 
O4 
4096 
O5 


12 
, 
OA 
10 
20 
oa 
2A 
I 
so 
04 
so 
F0 
02 
ca 
FF 
01 
cs 
FF 


A 
oc 


I 
32 


Notes: 


____ 
__ 
__ 
_ 
' 
4| 


1. Suggested values of GPL in Read or Write commands to avoid overlapping between Data field and ID field of contiguous sections. 
2. Suggested values of GPL in Format a Track command. 
3. In MFM mode the DDFDC cannot perform a read/write/format operation with 128 bytes/sector (N 
== 00). 
4. Values of ST and GPL are in hexadecimal. 


Result Phase: 


Fi 
1 
Status Register 0 (STO) 


2 
Status Register 1 (ST1) 


3 
Status Register 2 (ST2) 


4 
Track Number (T)‘ 


5 
Head Number (H)" 


6 
Sector Number (R)‘ 


7 
‘ 
Number of Data Bytes per Sector (N)‘ 


‘ The ID information has no meaning in this command. 


SCAN COMMANDS 


The scan commands compare data read from the disk to data 
supplied from the data bus. The DDFDC compares the data, and 
looks for a sector of data which meets the conditions of DFDD = 
DBUS, DFDD s DBUS, or DFDD 2 DBUS (D = the data pattern in 
hexadecimal). A magnitude comparison is performed (FF = 
largest number, 00 = smallest number). The hexadecimal byte 
of FF either from the bus or from FDD can be used as a mask 
byte because it always meets the condition of the compare. After 
a whole sector of data is compared, if the conditions are not met, 
the sector number is incremented (R + STP -—- R), and the scan 
operation is continued. The scan operation continues until one 
of the following events occur: the conditions for scan are met 
(equal, low or equal, or high or equal), the last sector on the track 
is reached (EOT), or TC is received. 
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If conditions for scan are met, the DDFDC sets the Scan Hit (SH) 
flag in ST2 to a 1, and terminates the command. If the condi- 
tions for scan are not met between the starting sector (as specified 
by R) and the last sector on the track (EOT), then the DDFDC 
sets the Scan Not Satisfied (SN) flag in ST2 to a 1, and terminates 
the command. The receipt of TC from the processor or DMA con- 
troller during the scan operation will cause the DDFDC to com- 
plete the comparison of the particular byte which is in process, 
and then to terminate the command. Table 6 shows the status 
of bits SH and SN under various conditions of scan. 


Table 6. 
Scan Status Codes 


St t 
R 
' t 
2 
Command 
I 
e---~--D--u-S 
Ie-9'8 er 
Comments 
Bit2 = SN 
I Bit3 = SH 


O 
Scan Equal 
1 


I 
Drpp 
Drpp 
6 
Deus 
Deus 
0 
Scan Low or Equal 
0 


1 


Drpp 
Drpp 
Drpp 


< 
> 


Deus 
Deus 
Deus 


0 
Scan High or Equal 
I 
0 


1 


Drpp 
Drpp 
Drpp 


> 
< 


Deus 
Deus 
Deus 


If SK = O and the DDFDC encounters a Deleted Data Address 
Mark on one of the sectors, it regards that sector as the last sec- 
tor of the track, sets the Control Mark (CM) bit in ST2 to a 1 and 
terminates the command. If SK = 1, the DDFDC skips the sec- 
tor with the Deleted Data Address Mark, sets the CM flag to a 


1 in order to show that a Deleted Sector has been encountered, 
and reads the next sector. 


When either the STP sectors are read (contiguous sectors = O1, 
or alternate sectors = 02) or MT (Multi-Track) is set, the last sec- 
tor on the track must be read. For example, if STP = 02, MT 
= 0, the sectors are numbered sequentially 1 through 26, and 
the scan command starts reading at sector 21. Sectors 21, 23, 
and 25 are read, then the next sector (26) is skipped and the Index 
Hole is encountered before the EOT value of 26 can be read. 
This results in an abnormal termination of the command. If the 
EOT had been set at 25 or the scanning started at sector 20, then 
the scan command would be completed in a normal manner. 


During a scan command data is supplied from the data bus for 
comparison against the data read from the disk. In order to avoid 
having the Over Run (OR) flag set in ST1, data must be available 
from the data bus in less than 27 p.S (FM mode) or 13 its (MFM 
mode). If an OR occurs, the DDFDC terminates the command 
and sets bits 7 and 6 of STO to 0 and 1, respectively. 


The following tables specify the command bytes and describe 
the result bytes for the three scan commands. 


SCAN EQUAL 
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Command Phase: 
T W 
W T H 
rt/w 
(BYTE 
7 
6 
5 
4 
3 
2 
1 
O 


r’ 
1 
W 
‘ 
1 
MT 
1 
oro 
0 
1 
MF 
SK 
I 


2 
x 
x 
x 
x 
x 
HD 
us1 
uso 


-1 
3 
Track Number (T) 


4 
Head Number (H) 


5 
Sector Number (R) 


6 
Number of Data Bytes per Sector (N) 


7 
End of Track (EOT) 


8 
I Gap Length (GPL) 


9 
Sector Test Process (STP) 


Result Phase: 


1 
Status Register 0 (STO) 
w 


F 


I 
2 
Status Register 1 (ST1) 


Status Register 2 (ST2) 


4 
Track Number (T) 


5 
Head Number (H) 


6 
Sector Number (R) 


7 
Number of Data Bytes per Sector (N) 


SCAN LOW OR EQUAL 


Command Phase 


R/W 
BYTE 
7 
6 
5 
4 
3 
2 
1 
0 
w 
1* 
MT 
MFSK11O 
O1 
2XXXXX 
HD ‘us1 
uso 


-1 
Track Number (T) 
_ 


-1 


I 
4 
Head Number (H) 
_ 


-1 


I 
5 
Sector Number (R) 


Number of Data Bytes per Sector (N) 


_L___ 


77% 
I 
End of Track (EOT) 


It 
_ 
3 
I Gap Length (GPL) 
D W 


)-I 


‘ 
9 
Sector Test Process (STP) 


Result Phase: 


R 
D Dstzettis Register o (sro) 


2 
Status Register 1 (ST1) 


3 
Status Register 2 (ST2) 
_ 


4 
Track Number(1) 
D 
I 
I 


5 
Head Number (H) 


6 


TI 
Sector Number (R) 
D 


7 
Number of Data Bytes per Sector (N) 
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SCAN HIGH OR EQUAL 


Command Phase: 
_ 
rt/w 
I BYTE 
7 
s 
5 
4 
3 
2 
1 
0 


x 
HD 


I 
7 
H 
____ 
W‘1gMTMFSK11101 
I2;xxxx 
ustuso 


5 
- 
__ 
:___i 
__ 
3 
Track Number (T) 


I 
4 
i 
Head Number (H) 


‘__ 
_ 
_ 
_ 
_ 
_ 
5 
Sector Number (R) 


6 
I 
Number of Data Bytes per Sector (N) 


7 
End of Track (EOT) 


8 
Gap Length (GPL) 


It 
"' 
' 
I 
_ 
_____ 
" 
9 
Sector Test Process (STP) 


Result Phase: 


R 
1 
1 
Status Register 0 (STO) 


2 
Status Register 1 (ST1) 


3 
Status Register 2 (ST2) 


4 
Track Number (T) 


5 
I 
Head Number (H) 


i’ 
2 
_ 
___ 
7 
____ 


I 


I 
6 
Sector Number (R) 


I 
-I 
I 
' 
_ 
_ 
' 
_ 
7 
Number of Data Bytes per Sector (N) 


SEEK 


The three-byte Seek command steps the FDD read/write head 
from track to track. The DDFDC has four independent Present 
Track Registers for each drive. They are cleared only by the 
Recalibrate command. The DDFDC compares the Present Track 
Number (PTN) which is the current head position with the New 
TrackNumber (NTN), and if there is a difference, performs the 
following operation: 


if PTN < NTN: Sets the direction output (LCT/DIR) high 
and issues step pulses (FR/STP) to the FDD 
to cause the read/write head to step in. 


If PTN > NTN: Sets the direction output (LCT/DIR) low and 
issues step pulses to the FDD to cause the 
read/write head to step out. 


The rate at which step pulses are issued is controlled by the Step 
Rate Time (SRT) in the Specify command. After each step. pulse 
is issued, NTN is compared against PTN. When NTN = PTN, 
then the Seek End (SE) flag in STO is set to a 1, bits 7 and 6 
in STO are set to 0, and the command is terminated. At this point 
DDFDC asserts INT. 


The FDD Busy flag (bit 0-3) in the Main Status Register (MSR) 
corresponding to the FDD performing the Seek operation is set 
to a 1. 


After command termination, all FDD Busy bits set are cleared by 
the Sense interrupt Status command. 


During the command phase of the Seek operation the DDFDC 
sets the Controller Busy (CB) flag in the MSR to 1; but during 
the execution phase the CB flag is set to 0 to indicate DDFDC 
non-busy. While the DDFDC is in the non-busy state, another 
Seek command may be issued, and in this manner parallel seek 
operations may be performed on all drives at once. 


No command other than Seek will be accepted while the DDFDC 
is sending step pulses to any FDD. If a different command type 
is attempted, the DDFDC will set bits 7 and 6 in STO to a 1 and 
0, respectively, to indicate an invalid command. 


If the FDD is in a not ready state at the beginning of the com- 
mand execution phase or during the seek operation, then the 
DDFDC sets the Not Ready (NR) flag in STO to a 1, sets STO 
bits 7 and 6 to 0 and 1, respectively, and terminates the command. 


If the time to write the three bytes of the Seek command exceeds 
150 tts, the time between the first two step pulses may be shorter 
than the Step Rate Time (SRT) defined by the Specify command 
by as much as 1 ms. 


Command Phase: 


I 
_ 
L 
_ 
__._W 
7 
_ 
re 
" 
4 
R/W 
BYTE‘ 
7 
6 
5 
4 
3 
2 
1 
O 
w71o 
O 
O 
O 
1 
1 
1 
1 
I2xxxxxous1uso 


3 
New Track Number (NTN) 


Result Phase: None. 


RECALIBRATE 


This two-byte command retracts the FDD read/write head to the 
Track 0 position. The DDFDC clears the contents of the PTN 
counters, and checks the status of the Track 0 signal from the 
FDD. As long as the Track 0 signal (TRKO) is low, the direction 
signal (LCT/DIR) output remains low and step pulses are issued 
on FR/STP. When TRKO goes high the DDFDC sets the Seek 
End (SE) flag in STO to a 1 and terminates the command. If the 
TRKO is still low after 256 step pulses have been issued, the 
DDFDC sets Seek End (SE) and Equipment Check (EC) flags in 
STO to 1s, sets bits 7 and 6 of STO to 0 and 1, respectively, and 
terminates the command. 


The ability to do overlap Recalibrate commands to multiple FDDs 
and the loss of the RDY signal, as described in the Seek com- 
mand, also applies to the Recalibrate command. 


Command Phase: 


R/W 
BYTE 
7 
6 
5 
4 
3 
2 
1 
O 


O 
O 
O 
1 
1 
1 


2 
X 
X 
X 
X 
X 
O 
US1 
USO 


W 
1 
O 
0 


Result Phase: None. 


A 


® VLSI TECHNOLOGY, INC. 


SENSE INTERRUPT STATUS 


Interrupt Request (INT) is asserted by the DDFDC when any of 
the following conditions occur: 


1. Upon entering the result phase of: 
a. Read Data command 
b. Read a Track command 
c. Read ID command 
d. Read Deleted Data command 
e. Write Data command 
f. Format a Track command 
g. Write Deleted Data command 
h. Scan commands 
2. Ready (RDY) line from the FDD changes state 
3. Seek or Recalibrate command termination 
4. During execution phase in the Non-DMA mode 


INT caused by reasons 
1 and 4 above occur during normal 
command operations and are easily discernible by the processor. 
During an execution phase in Non-DMA mode, bit 5 in the MSR 
is set to 1. Upon entering result phase this bit is set to 0. Reasons 


1 and 4 do not require the Sense Interrupt Status command. The 
interrupt is cleared by reading or writing data to DDFDC. Inter- 
rupts caused by reasons 2 and 3 are identified with the aid of 
the Sense Interrupt Status command. This command resets INT 
and sets/resets bits 5, 6, and 7 of STO to identify the cause of 
the interrupt. Table 7 defines the seek and interrupt codes. 


The Sense Interrupt Status command is used in conjunction with 
the Seek and Recalibrate commands which have no result phase. 
When the disk drive has reached the desired head position the 
DDFDC asserts interrupt output. The host CPU must then issue 
a Sense Interrupt Status command to determine the actual cause 
of the interrupt, which could be Seek End or a change in ready 
status from one of the drives (see example in Figure 4). 


Issuing a Sense Interrupt Status command without an interrupt 
pending is treated as an invalid command. 


Table 7. 
STO Seek and Interrupt Code Definition for 
Sense Interrupt Status 


Status Register 0 
(STO) Bits 


Interrupt Code 
‘ 
Seek End 
(I9) 
($5) 
I 
7 
" 
I 
Cause 
7 
6 
5 


*7 
_ ___ 
, 
if 
I 
_______ 
_ WW 
_ 
_ 


1 
1 
O 
RDY line changed 
state, either polarity 
g 
W 


0 
0 
I 
1 
I 
Normal termination of 


I 
Seek or Recalibrate 


I 
command 


0 
1 
1 
Abnormal termination of 
Seek or Recalibrate 


I 
command 
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Command Phase: 
_ 


W 
1 
O 
O 
O 
O 
1 
O 
O 
O 


R/W 
BYTE 
7 
6 
5 
4 
3 
2 
1 
‘ 
O 


Result Phase: 


Status Register 0 (STO) 


Present Track Number (PTN) 


SPECIFY 


The three-byte Specify command sets the initial values for each 
of the three internal timers. The Head Unload Time (HUT) defines 
the time from the end of the execution phase of one of the readl 
write commands to the head unload state. This timer is program- 
mable from 16 to 240 ms in increments of 16 ms (1 = 16 ms, 
2 = 32 ms,. . .F = 240 ms). 


The Step Rate Time (SRT) defines the time interval between 
adjacent step pulses. This timer is programmable from 1 to 16 ms 
in increments of 1ms (F =1 
ms, E = 2 ms, D = 3ms,. .. 
0 = 16 ms.) 


The Head Load Time (HLT) defines the time between the Head 
Load (HDL) signal going high and the start of the read/write 
operation. This timer is programmable from 2 to 254 ms in 
increments of 2 ms (01 
= 2 ms, 02 = 4 ms, 03 = 6 ms,. .. 
7F = 254 ms). 


The time intervals are a direct function of the clock (CLK on pin 19). 
Times indicated above are for an 8 MHz clock. If the clock is 
reduced to 4 MHz (mini-floppy application) then all time intervals 
are increased by a factor of two. 


The choice of DMA or Non-DMA operation is made by the Non- 
DMA mode (ND) bit. When this bit = 
1 the Non-DMA mode is 
selected, and when ND = 0 the DMA mode is selected. 


Command Phase: 
rt/w 
BYTE 
7 
6 
5 
4 
3 
2 
1 
0 


_ 
5 
___ 
__) 
_ 
___ 
W 
1OIOOOOO1I1 


2 
SRT 
HUT 


3 
HLT 
ITip 


SRT — Step Rate Time 
HUT— Head Unload Time 
HLT — Head Load Time 
ND — Non-DMA mode 


Result Phase: None. 
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Figure 4. 
Sense Interrupt Status 
VL6765 


Hi Seek (or Recalibrate) Command -—--I- Sense Interrupt Status Command -| 
"I 
Command Phase —>|-— Execution Phase —--1-Command Phase-I-— Result Phase -1 
mr__i_ 


c_s 


A0 TI__I_J"L 
LI 
'I_II_L 
ITL 


I 
up 
ITI 
' 
I-J 
HIT 
R» 
I 
W" Tii'__ 


,I>I<>—FTFT 


OP 
CODE 
FOR 
NSTRUCT 
ON WRTTENNTO 
DDFDC 
HD/DR 
VENOTWRTTN 
NTO 
FDC 
NTN 
NWR 
TTE 


NTODDFDC 


E DD 


SENSE DRIVE STATUS 


This two-byte command obtains and reports the status of the FDDs. 
Status Register 3 (ST3) is returned in the result phase and con- 
tains the drive status. 


Command Phase: 
i 
g 
W 
i 
i 
R/W 
BYTE 
7 
s 
5 
4 
3 
2 
1 
0 


x 


W 
1 
O 
O 
O 
0 
O 
1 
O 
O 


2 
X 
X 
X 
X 
HD 
US1 
USO 


Result Phase: 


R 
I 
1 
IStatus Register3(ST3) 


INVALID COMMAND 


If an invalid command (i.e., a command not previously defined) 
is received by the DDFDC, then the DDFDC terminates the com- 
mand after setting bits 7 and 6 of STO to 1 and 0, respectively. The 
DDFDC does not generate an interrupt during this condition. Bits 
6 and 7 (DIO and ROM) in the MSR are both set to a 1 indicating 
to the processor that the DDFDC is in the result phase and that 
STO must be read. A hex 80in STO indicates that an invalid com- 
mand was received. 


A Sense lnterrupt Status command must be sent after a Seek or 
Recalibrate interrupt, otherwise the DDFDC considers the next 
command to be an invalid command. 


In some applications the user may wish to use this command as 
a No-Op command, to place the DDFDC in a standby or no opera- 
tion state. 


O 
CODE 
FOR 


TRUCT 
ON 


WR 
TTEN NTO 
DDFDC 
STATUS 
REGSTERSTO 
READBYCPU 
PTNREAD 
BY 
CPU 
P NS 


Command Phase: 
/w 
BY E 
7 
I 
I I 0- 
Invalid Codes 


Result Phase: 


R 
I 
1 
Istattts Register0(STO) = so 


PROCESSOR INTERFACE 


During the command or result phases, the Main Status Register 
(MSR) must be read by the processor before each byte of infor- 
mation is transferred to, or from, the DDFDC Data Register. After 
each byte of data is written to, or read from, the Data Register, 
the processor should wait 12 tts before reading the MSR. Bits 6 
and 7 in the MSR must be a 0 and 1, respectively, before each 
command byte can be written to the DDFDC. During the result 
phase, bits 6 and 7 of the MSR must both be 1s prior to reading 
each byte from the Data Register onto the data bus. Note that 
this status reading of bits 6 and 7 of the MSR before each byte 
transfer to and from the DDFDC is required in only the command 
and result phases and not during the execution phase. 


During the result phase all bytes shown in the result phase must 
be read by the processor. The Read Data command, for example, 
has seven bytes of data in the result phase. All seven bytes must 
be read to successfully complete the Read Data command. The 
DDFDC will not accept a new command until all seven bytes have 
been read. Other commands may require fewer bytes to be read 
during the result phase. 
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Figure 5. 
DDFDC and System Data Transfer Timing 


DATA IN/OUT 
(DIO) 


VL6765 


(MSR BIT 6) 
FROM DATA BUS To pprpc I 
I 
REQUEST 
I 
I 
I 
rort MASTER 
"“°' 
I 
' 
(Rot-I) 
I 
I 
' 
I 
(msrt BIT7) 
I 
|R£ADY| 
| 
| 
| 
| 
| 
| 
I 
, 
| 
i_ 
' 
' 
t 
. 
0 
I 
WRiTE(WR) L—#i{ 


I 
I 
I 
I 
I 
I 
I 
, 
I 
| 
READ(RD) III 
I:||I||| 


I 
I 
I 
IIIQZ-EIKIIIEIIIEIEIK 


[E DATA REGISTER READY TO BE WRITTEN INTO 
E] DATA REGISTER READY FOR NEXT DATA BYTE To BE READ 


NOTES 


DATA REGISTER NOT READY TO BE WRITTEN INTO 
IE DATA REGISTER NOT READY FOR NEXT DATA BYTE TO BE READ 


INTERRUPT REQUEST MODE 


During the execution phase, the MSR need not be read. The 
receipt of each data byte from the FDD is indicated by INT high 
on pin 18. When the DDFDC is in Non-DMA mode, INT is asserted 
during the execution phase. When the DDFDC is in the DMA 
mode, INT is._asIserted at the result phase. The INT signal is reset 
by a read (RD low) or write (WI low) of data to the DDFDC. 
A further explanation of the INT signal is described in the Sense 
interrupt Status command on page 16. If the system cannot 
handle interrupts fast enough (within 13 tts for MFM mode or 27 tts 
for FM mode), it should poll bit 7 (ROM) in the MSR. In this case, 
ROM in the MSR functions as an Interrupt Request (INT). If the 
ROM bit is not set, the Over Run (OR) flag In ST1 will be set to 
a 1 and bits 7 and 6 of STO will be set to a 0 and 1, respectively. 


DMA MODE 


When the DDFDC is in the DMA mode (ND = 0 in the third com- 
mand byte of the Specify command), DRO (DMA Request) is 
asserted during the execution phase (rather than INT) to request 
the transfer of a data byte between the data bus and the DDFDC. 


During a read command, the DDFDC asserts DRO as each byte 
of data is available to be read. The DMA controller respgls to 
this request with DACK low (DMA Acknowledge) and RD low 
(read). When DACK goes low the DMA Request is reset (DRO 
low). After the execution phase has been completed (TC high or 
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the EOT sector is read), INT is asserted to indicate the begin- 
ning of the result phase. When the first byte of data is read dur- 
ing the result phase, INT is reset low. 


During a write command, the DDFDC asserts DRO as each byte 
of data is required. The DMA controller respon_(1s~._to this request 
with 
DACK (DMA Acknowledge) 
and 
WR 
low (write). 
When DACK goes low the DMA Request is reset (DRO low). After 
the execution phase has been completed (TC high or the EOT 
sector is written), INT is asserted. This signals the beginning of 
the result phase. When the first byte of data is read during the 
result phase, the INT is reset low. 


FDD POLLING 


After the Specify command has been received by the DDFDC, 
the Unit Select lines (USO and US1) begin the polling mode. 
Between commands (and between step pulses in the Seek Com- 
mand) the DDFDC polls all the FDD’s looking for a change in 
the RDY line from any of the drives. if the RDY line changes state 
(usually due to the door opening or closing) then the DDFDC 
asserts INT. When Status Register 0 (STO) is read (after Sense 
interrupt Status command is issued), Not Ready (NR = 1) will 
be indicated. The polling of the RDY line by the DDFDC occurs 
continuously between commands, thus notifying the processor 
which drives are on- or off-line. Each drive is polled every 1.024 ms 
except during read/write commands. 
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Figure 6. 
DDFDC Formats 


FM MODE 


new 
oAP 4; 
svuc 
|Au 
GAP 1 
\ svuc 
mm 
cvn. 
no 
sac 
no 
cnc 
GAP 2 
svnc 
oArA Au 
DATA 
GAP a 
GAP 4b 


uo.o|= avrss 
40» 
Ox 
an 
Ox 
11» 
Ox 
(D 
cnc 
(D 


FC 
FF 
oo 
FE 
FF 
DATA 
U 
FB OR Fl 


mosx __/_\_ 
~ 
~ 
'REPEAT um/res 
- 


MFM MODE 


\ 
_ 
V, 
— 
"'_ 
—~'— 
— 
_ 
-W 
*7-r 


GAP 4; 
svnc 
|Au 
GAP 1 
svnc 
mm 
CYL 
no 
sec 
no 
cac 
GAP 2 
svnc 
DATA Au 
oA'rA 
GAP 3 
GAP 4b 


an 1 
X 
x 
2 X 
a x 
2:: 
12 I 
a x 
FB 
(D 
cnc 
@ 


4|: 
oo 
A1 
FE 
4: 
oo 
A1 
Fa 


INDEX‘/1 
Q 
* 
-—- 
- 
— 
— 
-— 
REPEAT N TIMES i 


Figure 7. 
DDFDC Formats 


mosx 
/—\ 
/*\ 


FORMAT 
FQAP 4a||AM I GAP 1 L no Io-AP 2 I DATA [GAP 3| 
|0|aAP an 


v<=<>sv~<= 


we 
i" ““““ ""\\ 
I 


NOTE: .__._ READ 
_ _. _. _ WRITE 
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Figure 8. 
VL6765 DDFDC Interface I0 Z80 


Z80 
PSO 
PS 
CPU 
WDA 


A1-A15 


I 
I 


O I‘ 
sw—z 


D0-D7 
V 


I210: 


I- 
‘Inux 
RDW 
1 


‘é%8—-—>-‘ R5231/Asnv 


LO 
SIV 


PRE COMP 


MEMORY 
WP/T5 
FLT/TRKO 
Mux 


-_ 
FR/STP 
LCT/DIR 
MUX 


WRITE 
gg;sEE*< 
CLOCK 
~— WE 
*—* 


j 
ILDX 
L 
_ 


L HOL 
HD_ 


VL6765 


READ DATA 


WRITE DATA 


WRITE PROTECT 
TWO-SIDE 
FAULT 
TRACK 0 
FAULT RESET 
STEP 
LOW CURRENT 
DIRECTION 


READY 
WRITE ENABLE 
INDEX 
HEAD LOAD 
HEAD SELECT 
UNIT SELECT 0 
UNIT SELECT 1 
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Figure 9. 
Clock Timing 


0 


0 
0 
0 


Figure 10. 
Read Cycle Timing 


~>»E§ 
@ 
e 
bl 


@ 


D0-D7 
® 


INT 


Figure 11. 
Write Cycle Timing 


A0 Fs 


VL6765 


» 


TR 
—@— 


O 
O 
°‘$T,'i.'§i 
_"in 


INT 
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Figure 12. 
DMA Operation Timing 


O 


DRO 


@® 


DACKIi 
@ 
W5 on E6 


Figure 13. 
FDD Write Operation Timing 


WRITE CLOCK 
Q 
(wcx) 
* 
® 
.‘ 
Q, 


WRITE ENABLE 
‘ 
(WE) 


PRESHIFT 0 OR 1 @ 
Pa 
(PS0, PS1) 
iii 
ea 
wnmz DATA 
(WDA) 


Figure 14. 
FDD Read Operation Timing 


READ DATA (non) 
I 
O 
O 
O 


NOTE: 
EITHER POLARITY DATA WINDOW IS VALID 
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Figure 15. 
Seek Operation Timing 


USO, US1 


—~ 
@ 


___SEEK 
(nw/sssrq 


VL6765 


I 
STABLE 
' 


@ 


omecnou 
(Lcnonn 


STEP 
(FR/STP) 
' .- 


Figure 16. Fault Reset Timing 
Figure 


FAULT RESET 
(FR) 


17. 
index Timing 


INDEX 
(IDX) 


Figure 18.. Terminal Count Timing 
Figure 19. 
Reset Timing 


TERMINAL COUNT 


(Tc) 
I 
I 
1| 
—>ir'- 
#1 


Figure 20. AC Timing Measurement Conditions 


TEST POINT 


RESET 
(nsr) ___m___ 


I 
IP- 


TEST 
POINT 
I 
I 
INPUTIOUT 
CLOCK 


. 
.0V 
2 ‘V 
2.0V 
2.0V 
3 
2.4v ' 
2.4v 


0'45‘, 
0.8V 
0.8V 
0.3V 
0.65V 
0.65V 


INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC “1” AND 0.45 V FOR 
CLOCKS ARE DRIVEN AT 3.0V FOR A LOGIC "1" AND 0.3V FOR A 
A LOGIC “01’ TIMING MEASUREMENTS ARE MADE AT 2.0V FOR 
LOGIC “OI’ TIMING MEASUREMENTS ARE MADE AT 2.4V FOR A 
A LOGIC "1" AND 0.8V FOR A LOGIC “0I’ 
LOGIC “1" AND 0.65V FOR A LOGIC "01’ 
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AC CHARACTERISTICS 
(vcc = 5.0 Vdc 15%. vss = 0 Vdc, TA = 0°C to 70°C) 


VL6765 


Ref.I 
Fig.\MNo.i 
i 
i 
Characteristic 
i 
Symbol 
Alt. Sym. 
Min. 
Max. 
Test 
I 
Unit 
Conditions 


F 
. 
s" 
3-1/2"FDD 
1 
<='<><=*<P~~<><* 
I ‘P <8-meet ’ 
¢cY 
120 
TYP 
125 
222520 22 2 
500 


1 
2 
ns 
ns 
CLK 
8 MFIz 
CLI? = 4 MR2‘ 


IO 
8 
Clock High 
_ 
i 
i 
ICA 
¢0 
40 
RS 
a MHz 
CLK = 
I 
I Clock Rise Time 
(A) 
22 
ICLCH 
¢i 
I20 
RS 
‘Clock Fall Time 
_ 
_ 
i 
i 
i 
J=~ 
ICHCL 
<51 
20 
RS 


O1 
“ A0, c_s, DACK veiia to F6 Low (Setup) 
ism 
‘A8222 
22 
0 
Q32 
pi 
2 
22 
— 
__ 
22 
_ 
A 
ii 
RD High to A0, CS, DACK lnvaIid_(Hoid) 
IRHSH 
CD 
IRA 
0 
RS 


\I 
E Low Width 
1%,. 
IHF1 
if 256 
RS 
i__ 


~ RD Low to Data Valid (Access) 
IRLDV 
OD 
Iao 
39° 
RS 
RD High to Output High Z 
2 
22 
2 
22 
IH_Hoz 
(O 
JDF 
222292 
2 
100 
RS 
CL = 


R5 Highto INT High i 


1 
10 
ii 
_ 
_ 
iiIi=iHiH 
‘R12 
2 599 
22 ‘T52 
CLK = 8 MHZ 


i 11 
A0, cs, DACK Vaiidito wR_i_pii (Setup) 
ism 
‘Aw 
0 
RS 


I 12 
wn Highiiiq A0, cs, DACK Invalid (Hold) 
IWHSH 
FwA 
_2 
RS 


10 
_ 
W15 LOW 
7 
L 
IWLWH 
Iww 
250 
RS 
14 
Data}/iaiiiid to we High (Setup) 
_ 
Himiovwp 
Iow 
‘150 
RS 
153 i"vHigh to Data Invalid (Hold) 
I 
I 
Z 
TWHDX 
‘W02 
I 2 
5 
RS 
18 
W'FiHighipii\ifi-“iigh 
;iw,.,,, 
tWl 
I 
500 
RS 


17 
I 
Iocv 
Ihicv 
13 
iiS 
I DRO Cycle Time??? 
i 
i 
I W 
_ 


i 18 
one Highto R-0, W High (Response) 
IQHXH 
Iiiaw 
(12 
(18 
CLK = 8 MHZ 


IALQL 


IQHAL 


IQHRL 


19 
‘ DACK Low to DRO Low (Delay) 
19a 
DRO High to DACK Low (Delay) 
I1 
IAM 


tMA 


IMR 


200 


800 


200 
RS 


RS 


RS 
Icy = 13252 2'35 
20 
_ DRQ High to RD Low (Delay) 
DROiHigh to WR Low (Delay) 
_ 
_ _ J 
(8" or 3-1/2" FDD) 
I 
WCK Cycle Time 
—p 
A 
(54/4,, FDD) 


IoHwi_ 
IKCY 
21 


Imw 
Icv 


250 


-to 


RS 


11$ 
___[lS 


CLK = 8 MHZ 


MFM=1 
I 


I\)J> 
;iS 
[IS 
T MFIV|?0_ 
MFM = 1”. 
' 22 
wok High Width 
__ 
IKHKL 
Io 
80 
250 
350 
RS 


23 
RISQ 
W 
7 
IKLKH 
It 
2° 
ins 


1 
_ 
_._. 
? 
2 
22 
12 
, 
IKHKL 
1,23 
20 
RS 


IKHPV 
ICP 
203 
100 
F25 
-i_ 25 
i 
2_ WCK High to PSO, PS1iiValid (oeiey) 


Icwis 
20 
g-i 
I00 
RS 
26 
I wcK_ High toWDA High 
imp 
‘co 
20 
100 
RS 


Iwoo_ 
22 2 
IKHKL‘ 5° 


I 


H ns 


I 
(a" or 3-1/2" FDD) 
A 
' ‘iwCY 
30 
Iwcv 
-in 
;iS 
yS 
MFM = 
1 


I\)-b 
p.S 


2 22 112$ 
MFM = 1 


i 
now Valid to RDD High (setup) 
i 
13 
IwvHH 
Iwno 
2 
152 
229$ 


S 32 
RDD Low I0iRDiWlnvaIid (Hold) 
imw, 
Inow 
15 
RS 
I33 
RDD High Width 
IRHRL 
Iaoo 
40 
H 
RS 
35 
‘us 
12 
P5’ 
as 
SEEK i.pwi9_us0,us1ihveiid(Hpid) 
iiiiisw, 
Isu 
15 
p.S 


Iso 
2 
Y 
14$ 
as 
DIR Invalid to SEEKTLow (Hold) 
1DxsL 
Ios 
30 
p.S 
14 
~ 
p— 
A 
A ~ 
A 
89W DIR Valid to STP High (Setup) 
_ _ 
tow“ 
Iosr 


A 


I 


I 
"3 
STP Low to oia ihvaii<i(Higiq) 
I 
TTLDX 
__I2sTo 
24 
ES 
STP Low to uso. us1 Invalid (Hold) 
I 
ITLUX 
41 
_ 
7 
i 
i 
Isru 
5 
p.S 


I 
STP High Width 
i 
A 
tTHTL* 
ISTE22 
2 
6 
7 
8 
14$ 
' 43 
STP Cycle Time 
I 
im, 
Isc 
ass 
_ 
— 
ROI9 1 
#5 
is 
I 
44 
FR High Width 
i 
ipm 
Fm 
CD 
- 
_1o 
p.S 


CLK = 8 MHZ 


IDX High Width 
ii 
I_iii,Hi,L 
16 
4s 
ii 
Iiox 
PM 
_AQ 
Icv 


‘T02 
2 
M 
Icv 
1a 
47 
I 
J 
iii 
IRHRL 
i 
IRS]: 
7 
7 if 
_AR 


Isc 
period, and 2 ms to 32 ms with 4 MHz 
1. 
= 
clock, 
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33 p.S min. is for different drive units. In the case of the same unit, ts¢ can rang 
undersoitwage control. 
__ 
e from 1 ms to 16 ms with 8 MHz clock 
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ABSOLUTE MAXIMUM RATINGS‘ 
parameter 
A 
" symbol 
vaiue 
' lijinui" 
‘NOTE: Stresses above those listed under ABSOLUTE MAXI- 


2_2 
_ 
; 
I 
T 
Supply Voltage 
VCC 
I -0.3 to +7.0 
V 
MUM RATINGS may cause permanent damage to the device. This 
is a stress rating only and functional operation of the device at 
Input Voltage 
Vm 
- 0.3 to + 7.0 
V 
these or any other conditions above those indicated in other sec- 


Output Voltage 
VOUT 
- 0.3 to + 7.0 
V 
tions of this document is not implied. Exposure to absolute max- 
imum rating conditions for extended periods may affect device 
Operating Temperature Range 
I 
TA 
0 to + 70 


I 
2 
2 
P 
_ 
2 


” 
' 
T 
” 
I' 
F’ 
' 
‘ 
I2C0 
reliability. 


Storage Temperature Range 
TSTG 
— 55 to + 150 12 C° 


OPERATING CONDITIONS 


Parameter 
Range 
i i 
VCC Power Supply 
5.0V i 5% 


OperatingTemperature 
0°C to 70°C 


DC CHARACTERISTICS 
(vcc = 5.0 Vdc 25%, vss = 0 Vdc, TA = 0°C to 70°C, unless otherwise noted) 


Parameter 
' 
Symbol 
Min 
I 
Max 
Unit 
Test Conditions 


Logic 
CLK and WCK 


lnputLowVoltage 
v,L 
I 
I 
A 
I 
I 
0.5 
0.5 
0.8 
0.65 


Input High Voltage 
v,H 
Logic 
‘ 
CLK and WCK 
2.0 
vcc 'I' 


v 
vcc 
-I- 


Output Low Voltage 
VOL 


-if 
7 
I 
vcc = 4.75V,lOL = 2.0 mA 
0.45 
V 


Output High Voltage 
W 
VOH 
2.4 
VCC 
I 
V 
VCC = 
IQH = 
[AA 


vcc Supply Current 
ICC 
150 
I 
mA 
vcc = 4.75v 


Input Load Current 
i 


All Inputs 


IIL 


7 III 


I 
10 
I 
ii 
_ 
VIN = Vcc 
i 
_ 


V|N = 


_ 
FA 
-10 
[AA 


High Level Output Leakage Current 
ILOH 


Low Level Output Leakage Current 
ILOL 


‘ 
10 
I 
II-A 
vcc = ov to 5.25v, vss = ov 


I 
__ 
Vour =iVcc 
i 
_ 


-I0 
ILA 
VCC = 
TO 
vss = 


\ 
VOUT = 


Internal Power Dissipation 
PINT 


2 
— 
I" 
2 
1 
*7 
2 
* 
7 
- 
1.0 
w 
I 
TA = 25°C 


CAPACITANCE 
(TA = 25°C; re = 1 MHZ; vcc = ov) 


Parameter 
I 
Symbol 
I 
H‘ 
Max Limit 
I 
Unit 


2 
2 
1'— 
— 
2 
- 


CIOCK Input 
C|N(@) 
PF 


I 
I cm 
10 
Input 
( 
pF 
“I 
OUIPUI 
I 
I 
COUT 
I 


I Note: All pins except pin under test tied to ground. 
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' 
VL68C45R/S 
CRT CONTROLLER FAMILY 
DESCRIPTION 
The VL68C45X is a family of CRT 
controllers that are widely used in both 
bit-mapped and character-mapped 
applications for both terminals and 
personal computers. VL68C45 family 
allows designs to consume less power 
through the use of CMOS technology. 


FEATURES 


- CMOS technology 
-Rev R compatible with MC6845R1, 
MC6845 and MC146845 
-Rev S compatible with HD6845S 


- Internal refresh address generation 


In addition to compatibility with both the 
Motorola and Hitachi families, the 
VL68C45R also contains enhance- 
ments found in the MC6845R1. These 
enhancements allow for higher resolu- 
tion displays without extra external 
' Light pen interface 
hardwar9_ 


- Character clocks up to 8 MHz 


- Bus clocks up to 3 MHz 


- Single 5 V power supply 


PIN DIAGRAMS 


VL68C45R/S-PC,CC 
VL68C45R/S-QC 


CC1/ 


GND I 
-RES I 
LPEN I 
CCO/MAO I 
001/MA1 I 
C02/MA2 I 
C03/MA3 I 
C04/MA4 I 
005/MA5 I 
CC6/MA6 I 
CC7/MA7 I 
CRO/MA8 — 
CR1/MA9 I 
CR2/MA10 I 
CR3/MA11 I 
CR4/MA12 — 
CR5/MA13 — 
DIS EN - 
CURSOR — 
VCC - 


(DIO-* 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 


VSYNC 
HSYNC 
RAO 
RA1 
RA2 
RA3 
RA4/STB 
DSO 
DS1 
DS2 
DS3 
DS4 
DS5 
DS6 
DS7 
-CS 
RS 
E 
R/—W 
CCLK 


CC2/MA2 


CC3/MA3 


CC4/MA4 


7 


8 


9 


or-g <»I 


MAI 
LPEN 
GND 
HSYN 
RA1 
|°°°'| 
I 
I 
I 
MAO 
-RES 
VSYN 
RAO 
RA2 


43214443424140 
0 


CC5/MAS I 1o 


CC6/MA6 I 11 


CC7/MA7 I 12 
TOPVIEW 


CRO/MA8 I 13 


CR1/MA9 I 14 


CR2/MA10 I 15 


CR3/MA11 I 15 
NC17 
1819202122232425262728 
IIIIIIIIIII 
ca-1/ | ois 
vcc 
R/-W 
as 
NC 
MA12 
ENAB 
CR5! 
CUR- 
CCLK 
E 
-CS 
MA13 
SOR 


39 
RA3 


38 I RA4/STB 
370so 
35051 
35052 
34053 
33054 
32055 
31055 
30057 
29NC 


ORDER INFORMATION 
Clock Frequency 
Part 
Number 
Package 


VL68C45R-23 
VL68C45S-23 


VL68C45R-35 
VL68C45S-35 


VL68C45R-36 
VL68C45S-36 


VL68C45R-38 
VL68C45S-38 


3 MHz 
To specify package type, add the 
5 MHZ 
appropriate suffix to the part number: 


8 MHz 


PC = Plastic DIP 
CC = Ceramic DIP 
3 MHZ 
6 MHZ 
QC = Plastic Leaded Chip Carrier (PLCC) 


Note: Operating temperature range is 0°C to +70°C. 
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Slgnal 
Name 


E 


R/-W 


-CS 


RS 


DO - D7 


CCO/MAO — 
CC5/MA13 


RAO - 
RA4/STB 


HSYNC 


VSYNC 


DISPLAY 


CURSOR 


LPSTB 


CCLK 


-RES 


VCC 


GND 


Pln 
Number (DIP) 


23 


22 


25 


24 


26-33 


4-17 


34 - 38 


39 


40 


18 


19 


3 


21 


2 


20 


1 
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SIGNAL DESCRIPTIONS 
VL68C45R/S 


Slgnal 
Descrlptlon 


Enable - Input that is used as a data strobe; does not have to be a free-running clock. This 
capability allows the VL68C45 to interface with other non-6800/6500-type microprocessors. 


Read/-Write - Input that, when high, allows the processor to read the data supplied by the 
VL68C45; when this signal is low, the processor writes into the VL68C45. 


-Chip Select - Input that, when high, deselects VL68C45; when this signal is low, the 
VL68C45 is selected. This signal is typically connected to the system address bus either 
directly or through an address decoder. 


Register Select - Input that, when low, selects the Address Register of the VL68C45 for a 
write operation. When this signal is high, an internal register of the VL68C45 specified by the 
contents of the address register is selected. 


Data Bus - Eight bidirectional data lines that are used for transferring data between the 
microprocessor and the VL68C45. These lines are normally high-impedance, except during 
read and write cycles when the chip is selected. 


Video Memory Address - Active-high output signals that are used to address the video 
display memory in binary addressing mode. These memory addresses are generated in a 
binary sequential fashion. 


In row/column addressing mode, MAO-MA7 function as column addresses, and MA8-MA13 
function as row addresses. 


Raster Address - Active-high output signals that are used as address lines to the external 
character generator ROM. In the transparent addressing mode, RA4 functions as an active- 
high output strobe. 


Horizontal Sync - Active-high TTL-compatible output signal that is used to determine the 
horizontal position of the displayed text. VSYNC may be used to drive a CRT monitor directly 
or may be used for composite video generation. VSYNC position is fully programmable. 


Vertical Sync - Active-high, TTL-compatible output signal that is used to determine the 
vertical position of the displayed text. VSYNC may be used to drive a CRT monitor directly or 
may be used for composite video generation. VSYNC position is fully programmable. 


Display Enable - TTL-compatible output that, when high, indicates that the VL68C45 is 
generating active display information. The number of horizontal displayed characters and the 
number of vertical displayed rows are both fully programmable and together are used to 
generate the Display Enable signal. 


Cursor - TTL-compatible output that when high, indicates a valid cursor address to the 
external video processing logic. 


Light Pen Strobe - high impedance, edge-sensitive input signal that latches the current 
refresh address into the light pen register. Latching occurs on the low-to-high transition edge. 


Character Clock - Input signals derived from the external dot clock, that is used as the time 
base for all internal count and control functions. 


-Reset - Input signal that when low, resets all internal counters. All scan and video outputs 
are low and all control registers are unaffected. RES can be used to synchronize display 
frame timing with the line frequency. 


Power Supply Voltage is 5 V. 


Ground - Supply and signal ground 
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FUNCTIONAL 
DESCRIPTION 
The VL68C45 CRT Controller (CRTC) 
consists of programmable horizontal and 
vertical timing generators, program- 
mable Iinear address registers, program- 
mable cursor Iogic, a light pen capture 
register and control circuitry for interface 
to a processor bus. 


All CRTC timing is derived from the 
character clock (CCLK), which is usually 
the output of an external dot rate 
counter. Coincidence circuits internal to 
the chip continuously compare counter 
contents to the programmed register file 
(R0-R17) for generation of Horizontal 
Sync, Vertical Sync, Display Enable, 
Cursor and other signals required to 
interface to a CRT display. 


The linear address generator is also 
driven by the CCLK and locates the 
positions of characters of memory. The 
CRTC addresses the memory in the 
binary sequential fashion. Using the 
start address register, hardware 
scrolling through the 16k character 
memory is possible. The linear address 
generator continues to increment during 
the blanking period, so memory refresh 
can be performed during the blanking 
periods. The linear address generator 
repeats the same sequence of ad- 
dresses for each scan line of a charac- 
ter row. Although the linear address 
generator continues to increment during 
the horizontal and blanking periods, the 


FIGURE 1a. 
NORMAL SYNC 
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correct address for the first displayed 
character or row is always maintained. 


The Cursor logic determines the cursor 
location, size and blink rate on the 
screen. 


The Light Pen Strobe latches the 
current contents of the address counter 
into the light pen register on low-to-high 
transition. 


INTERLACE MODE SELECTION 
In the normal sync mode (non-inter- 
Iace), only one field is available, as 
shown in Figure 1a. Each scan line is 
refreshed at the VSYNC frequency (50 
or 60 Hz). 


Two interlace modes are available as 
shown in Figure 1b and Figure 1c. The 
frame time is divided between even and 
odd alternating fields. The horizontal 
and vertical timing relationship (VSYNC 
delayed by one-half scan line time) 
results in the displacement of scan lines 
in the odd field with respect to the even 
field. 


In the interlace sync mode, the same 
information is painted in both fields, as 
shown in Figure 1b. This is a useful 
mode for filling in a character to en- 
hance readability. 


ln the interlace sync and video mode, 
as shown in Figure 1c, alternating lines 
of the character are displayed in the 
even field and the odd field. This 


FIGURE 1b. 
INTERLACE SYNC 


scm um; ADDRESS 
oi-——-—i—-—-— 
iiiiiiig.-Zia 
1—e-——————e— 
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“ , 
; . 
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EVEN 
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effectively doubles the given band width 
of the CRT monitor. 


Care must be taken when using either 
interlace mode to avoid an apparent 
flicker effect. This flicker effect is due to 
the doubling of the refresh time for all 
scan lines since each field is displayed 
alternately and may be minimized with 
proper monitor design i.e., longer 
persistence phosphors. 


VL68C45R REGISTER FILE 
DESCRIPTIONS 
The 19 registers of the CRTC may be 
accessed through the data bus. Only 
two memory locations are required, as 
one location is used as a pointer to 
address one of the remaining 18 
registers. These 18 registers control 
horizontal timing, vertical timing, 
interlace operation and row address 
operation. They also define the cursor, 
cursor address, start address and light 
pen register. The register addresses 
and sizes are shown in Table 1. 


ADDRESS REGISTER (AR) 
The Address Register is a 5-bit write- 
only register used as an “indirect” or 
“pointer” register. It contains the 
address of one of the other 18 registers. 
When both RS and —CS are low, the 
Address Register is selected. When 
—CS is low and RS is high, the register 
pointed to by the address register is 
selected. 


FIGURE 1c. 
INTERLACE SYNC AND VIDEO 
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VL68C45R REGISTER FILE 
DESCRIPTIONS (Cont.) 
When the programmed value of this 
HORIZONTAL TQTAL REG|51'E|q (R0) 
register is increased, the display on the 
This 8-bit write-only register determines 
the horizontal sync (HSYNC) frequency 
by defining the HSYNC period in 
character times. It is the total of the 
displayed characters plus the non- 
displayed character times (retrace) 
minus one. 


HORIZONTAL DISPLAYED 
REGISTER (R1) 
This 8-bit write-only register determines 
the number of displayed characters per 
line. Any 8-bit number may be pro- 
grammed as long as the contents of R0 
are greater than the contents of R1. 


HORIZONTAL SYNC POSITION 


CRT screen is shifted to the left. When 
the programmed value is decreased, 
the display is shifted to the right. Any 8- 
bit number may be programmed as long 
as the sum of the contents of R2 and 
R3 is less than the contents of R0. The 
contents of R2 must be greater than R1. 


SYNC WIDTH REGISTER (R3) 
This 8-bit write-only register determines 
the width of the HSYNC pule. The 
vertical sync pulse width is fixed at 16 
scan-line times. HSYNC pulse width 
may be programmed from 1 to 15 
character clock periods, thus allowing 
compatibility with the HSYNC pulse 
width specifications of many different 
REGISTER (R2) 
monitors. If zero is written into this 
This 8-bit write-only register controls the 
HSYNC position, which defines the 
register, no horizontal sync is provided. 


horizontal sync delay (frontporch) and 
I'IORIz°NTAI- TIMING SUMII-IIAI:IY_ 
the horizontal scan delay (back porch). 
The dlII°l°"¢° b°IW°°" R0 and RI '9 
the horizontal blanking interval. This 


interval in the horizontal scan period 
allows the beam to return (retract) to the 
left side of the screen. The retrace time 
is determined by the monitor horizontal 
scan components. Retrace time is less 
than the horizontal blanking interval. 


A good rule of thumb is to make the 
horizontal blanking about 20% of the 
total horizontal scanning period for a 
CRT. In inexpensive TV receivers the 
beam over-scans the display screen so 
that aging of parts does not result in 
underscanning. Because of this, the 
retrace time should be about one-third 
the horizontal scanning period. The 
horizontal sync delay is typically 
programmed with a 1:2:2 ratio. 


VERTICAL TOTAL REGISTER (R4) 
AND VERTICAL TOTAL ADJUST 
REGISTER (R5) 
The vertical sync (VSYNC) frequency is 
determined by both R4 and R5. The 
calculated number of character row 


TABLE 1. VL68C45R INTERNAL REGISTER ASSIGNMENTS 


_c3 RS I 
Address Register 
'IRegIster 
3 
2 
1 
# 
-5 
O 
I 
I 
‘I 
_ 
I 
Register File ' 
Unit 
Program 
Read 
1, 
wme 
I 
g 
Numbe_rofB_its _v 
L W_ 
1 
I e 
I 5 
I 4 
3 
2 
1 
0 
x 
Ix" 
x 
X 
X 
X 
X 


X 
X 
X 
X 
1” 
' 
is 
AR 
Q 
O 
I Address Register 
I 


I 
I 
— 
#No 


7- 
Y‘?$ 
XI 
___ 
ac 
Q 
.4 
O 
O 
O 
O 
O 
I 
I 
'__T_'I 
z 
I 
I 
._I'_ 


I 
Horizontal Total 
I M 
Char. 
I 
No 
Yes 
F 


X 
4 
. 
1.-. 
...‘ ~ 
R1 
O 
-4 
O 
O 
O 
O 
If_1" 
I 
Horizontal Displayed 
y 
Char. 
If 
No 
Yes 


. 
R2 
O 
_. 
O 
Q 
—-.° T1. 


O 
H. Sync Position 
(‘W Char. 
I 
No 
Yes 
, 


__ 
__I_ 


g 
I 
ae- 
O 
-4 
Q 
O 
O 
..4 
..4 
I_T7"T'TI‘ 
7' 


I Syncwidth 
' 4 
I" ti. 
Yes 
H ' H 
H 


Q 
-4 
O 
O 
.4 
O 
O 
- 
R4 


I 
Vertical Total 


_l 
' 
'77" 
Char. Row 
No 


I 
I 
I 
1 


‘ 
. 
Yes 
I 
.. 
. 
. 
.R$ 


O 
.4 
O 
.4 
O 
.4 


_ 
_ 
E 
_ 
_ 
'77*’I 
V. Total Adjust 
Scan Line 
No 
Yes 
14.- 2. 


O 
-4 T 
CO 
-4 
-4 
O 
Vertical Displayed 


_._ 
~~ 
I 
____ 
Char. Row 
¥ 
No 
Yes 


I; 
I 
I 
; 
R1 
O 
“ 
-5 
To 
O 
.. 
_. 
V. Sync Position 
L Char. Row 
L 
No 


______ 
_ 
____ 
TI 
7 
Yes 


O 
.4 
Q 
O 
O 
.4 
.4 
T j 
R3 
I 
I. Sync Width 
Yes 


Q 
.4 
O 
.4 
O 
O 
-4 
W 
R9 
Max Scan Line Address 
I Scan Line 
I 
No 
Yes 


O 
.4 
.4 
O 
-4 
O 
. 
1_° . 
51° 
1. 
Cursor Start 


_ 
_ 
" 
I_____ 
_ 


I 
if 
Scan Line 
N0 
Yes 
T 
(Note 2) 


R11 
Cursor End 
I 
N0 
l 
Yes 


oo 
-1- 


-§-5 
oo 
_L—L 
-o 
O-A 
O-A 


X-I 
I 
_1 


I-0;-q 
R12 
I 
I 
I 
I 
I___;_ 
I 
__ z" 
Start Address (H) 
I 


Scan Line 


No 
Yes 
| 
; 
A 1 


O 
.4 
Q 
.4 
.4 
O 
-4 
7 
i 
R13 
Start Address (L) 


_ 
___ 
7”. 
I 
X;l 


N0 
N 
F 
. 
_._ 
_ 
Yes 
, 
\ 


Q 
.4 
@ 
-4 
H-4 
.-" , Z 
R14 
Cursor (H) 
— 
Yes 
YesI0-0 
- 


I 
R15 
I 
Q 
.4 
Q 
-4 
.4 
.4 
-4 


I 
Cursor (L) 
I 
_ 
' 
Yes 
Yes 
. 
.. 
. 
I 
. 
- 
_ 


‘I 
'1 
P"- 
5 
O 
.4 
.4 I:> 
O 
O 
O 
R16 


“II 


1 
Light Pen (H) 


, 
R 
R 
-1 
"W 
1 
4.. 
* 


I 
— 
Yes 


1 
19""? 
Iir 
I 
lz 
No 
00 


R17 
o 
-L 
—L 
o 
o 
-1-. 
O ,1 
—L 


I 


- 
._-_ 
- I 
W 
. 
.4 
. 
. 
I 
_ 
Light Pen (L) 
— 
Yes 
N0 
. 


Notes: 
1. The interlace bits are described in Table 2. 


__ 
' 
" 
'7' 
‘l 
i 
'7' 
I 
_ 
I 
i 
,_ 
* 
I 
7 


2. Bit 5 of the cursor start raster register is used for blink period, control, and bit 6 is used to select blink or no-blink. 
3. Registers R4, R6 and R7 in the VL68C45R are eight bits wide, instead of seven, for compatibility with the Motorola 6845R1. 
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VL68C45R REGISTER FILE 
DESCRIPTIONS (Cont.) 
times is usually an integer plus a 
fraction to get exactly a 50 Hz or 60 Hz 
vertical refresh rate. The integer 
number of character row times minus 
one is programmed into the 7-bit write- 
only vertical total register (R4). The 
fraction of character line times is 
programmed into the 5-bit write-only 
vertical total adjust register (R5) as the 
number of scan lines required. 


VERTICAL DISPLAYED REGISTER 
(R6) 
This 7-bit write-only register specifies 
the number of character rows displayed 
on the CRT screen, and is programmed 
in character row times. Any number 
smaller than contents R4 may be 
programmed into R6. 


VERTICAL SYNC POSITION REGIS- 
TER (R7) 
This 7-bit write-only register controls the 
position of vertical sync with respect to 
the reference. It is programmed in 
character row times. When pro- 
grammed value of this register is 
increased, the display position of the 
CRT screen is shifted up. When the 
programmed value is decreased, the 
display position is shifted down. Any 
number equal to or less than the 
contents of R4 and greater than or 
equal to the R6 may be used. 


INTERLACE MODE AND SKEW 
REGISTER (R8) 
The VL68C45R only allows control of 
the interlace modes as programmed by 
the low-order two bits of this write-only 
register. Table 2 shows the interlace 
modes available to the user. These 
modes are selected using the two low 
order bits of this 6-bit write-only register. 


TABLE 2: INTERLACE MODE 
REGISTER 
Bit1IBit2r niece 


0 
¢ 
0 
Normal Sync Mode 


1 
0 
(Non-interlace) 


E 
I 
F 
I interlace Sync Mode 
F 
F 
O 
-4 


X 
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X 
interlace Sync and VIideorModeE I 


There are restrictions on the program- 
ming of the VL68C45R registers for 
interlace operation: 
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1. The Horizontal Total Register (R0) 
value must be odd (i.e., and even 
number of character times). 
2. For interlace sync and video mode 
only, the Maximum Scanline 
Address Register (R9) value must be 
odd (i.e., an even number of scan 
nes) 
3. For interlace sync and video mode 
only, the number (Nvd) programmed 
in to the Vertical Display Register (R6) 
must be one-half the actual number 
required. The even-numbered scan 
lines are displayed in the even field and 
the off-numbered scan lines are 
displayed in the odd field. 
4. For interlace sync and video mode 
only, the Cursor Start Register (R10 
and Cursor End Register (R11) must 
both be even or odd, depending on 
which field the cursor is to be displayed 
in. A full block cursor will be displayed 
in both the even and the odd field when 
the Cursor End Register (R11) is 
programmed to a value greater than the 
value in the Maximum Scan Line 
Address Register (R9). 


MAXIMUM SCAN LINE ADDRESS 
REGISTER (R9) 
This 5-bit write-only register determines 
the number of scan lines per character 
row, including the spacing, thus 
controlling operation of the row address 
counter. The programmed value is a 
maximum address and is one less than 
the number of scan lines. 


CURSOR CONTROL 
REGISTERS 
CURSOR START REGISTER (R10) 
AND CURSOR END REGISTER (R11) 
These registers allow a cursor of up to 
32 lines in height to be placed on any 
scan line of the character block. 
Register R10 is a 7-bit write-only 
register used to define the start scan 
line and the cursor blink rate. Bits 5 
and 6 of the Cursor Start Address 
Register control the cursor operation as 
shown in table 3. Non-display, display, 
and two blink modes (16 times or 32 
times the field period) are available. 
Register R11 is a 5-bit write-only 
register that defines the last scan 
cursor. 


When an external blink feature on 
characters is required, it may be 
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TABLE 3. CURSOR START REGISTER 


Bit6 Bit5 Cursor Display Mode 
g 


g 0 
0 )_Non-blink 


0 
A 
1 
CursorNon-display 


Blink 1/16field rate 


J‘ 


_; 


-o 


'-I 


A 
‘ Blink, 1/32 field rate 


necessary to perform cursor blink 
externally so that both blink rates are 
synchronized. Note that an invert/non- 
invert cursor is easily implemented by 
programming the CRT for a blinking 
cursor and externally inverting the video 
signal with an exclusive-OR gate. 


CURSOR REGISTER (R14-H, R15-L) 
This 14-bit read/write register pair is 
programmed to position the cursor 
anywhere in the refresh RAM area, thus 
allowing hardware paging and scrolling 
through memory without loss of the 
original cursor position. It consists of an 
8-bit low-order (MAO-MA7) register and a 
6-bit high-order (MA8-MA13) register. 


START ADDRESS AND 
LIGHT PEN REGISTERS 
START ADDRESS REGISTER (R12-H, 
R13-L) 
This 14-bit write-only register pair 
controls the first address output by the 
CRTC after vertical blanking. It consists 
of an 8-bit low-order (MAO-MA7) register 
and a 6-bit high-order (MA8-MA13) 
register. The start address register 
determines which portion of the refresh 
RAM is displayed on the CRT screen. 
Hardware scrolling by character or page 
may be accomplished by modifying the 
contents of this register. 


LIGHT PEN REGISTER (R16-H, 
R17-L) 
This 14-bit read-only register pair 
captures the refresh address output by 
the CRTC on the positive edge of a 
pulse input to the LPSTB pin. It consists 
of an 8-bit low-order (MAO-MA7) register 
and a 6-bit high-order (MA8-MA13) 
register. Since the light pen pulse is 
asynchronous with respect to refresh 
address timing, an internal synchronizer 
is designed into the CRTC. Due to 
delays in this circuit, the value of R16 
and R17 will need to be corrected in 
software. (See the bus timing diagram in 
the Timing Characteristics section). 
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TABLE 4. v|_eec4ss INTERNAL REGISTER ASSIGNMENTS, (Note 1) 


- 
Address 
R 
ister 
D818 
-cs as 
__FI¢_eI=§e' 
°9# 
Register Name 
Program Unit 
READ wnmz 
I 
_ 
_ 
4 
3 
2 
1 
0 
7 
I 
6 
iii 
I 
I 
. 
. 
. 
' 


1 
xxxxxx 
— 
i- 
— 


I 
I 
I 
I 
U1; 
I— 
&_"I-I 
."*r**' '7" 
'I"'*' 
7" 
I 
I 


0 
0 
x 
x 
x 
x 
x 
AR 
Address Register 
, 
- 
. 
>< 


I 
I 
I 
7 
.4 
I 
" 


0 
1 
0 
0 
0 
0 
0 
R0 
Horizonta|Total' 
Character 
I 
>< 
c 
I 
I 
, 


I 
q 
I 
J 
_. 
""T"" 
"" 
' 
7 
4 
7 
7 
1-17 


1-1 
" 
1| 
0 
1 
o 
o 
0 
o 
1 
R1 
Dflgfgyeg 
¢ Character 
>< 
0 
A 
, 


1 
I 
I 
_ 
I 
._._. 
_ 
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._. 
. 
. 
I 
' 
"" 
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1 
0 
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§§;'ifig2‘a'SY"°' 
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>< 
o 
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I 
I 
. 
’ 
‘ 
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. 
__l__ 
444.- l 
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I. 
.I._ 
_._I 
Vertical-Raster, 
, 
1 
I 
0 
1 
0 
0 
0 
1 
1 
R3 
Syncwidth 
Horizontal- 
>< 
0 
wv3 
wv2 
wv1;wvO 
wh3 
wh2 
wh1 
wh0 


‘ 
Character 
, 
‘ 


I 
-.1 
7. 
. 
...-..... 
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0 
I 
1 
0 
0 
1 
0 
0 
R4 
, VerticalTotaI* 
I Line 
>< 
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I 
I 


1 
1 
1 
_ 
I 
._._ 
I 
_ 
.4 
__ 
. 
_ 
'I 
' 
' 
' 
' 
J 
' 
' 
'7 
T 


I 
I 


I 
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1 
0 
0 
1 
0 
1. 
R5 
,VerticalTotal Adjust 
Raster 
>< 
o 


I 
I 
.._ 
.._. 
_.._._._ 
_. 
. 
_.. 
__ 
. 
7 
I. 
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1 
,0 
0 
1 
1 
0 
R6 
Vertical Displayed 
Line 
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I 
o 
I 
I 
I 


I 
I 
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4 
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0 
1 
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o 
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ILine 
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o 
I 
I 


01101000 
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:lnterlace&Skew 
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I 


__ 
__‘____—__ 
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————— 
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___ 
__I 
, 
, 
iii. 
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=0 
1 
0 
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1 
as 
Xgglgsim Basie’ 
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VL68C45S REGISTER FILE 
DESCRIPTIONS (Cont.) 
ADDRESS REGISTER (AR) 
This is a 5-bit register that is used to 
select 18 internal control registers (RO- 
R17). Its contents are the address of 
one of 18 internal control registers. 
Programming the data from 18 to 31 
produces no results. Access to R0-R17 
requires writing the address of the 
corresponding control register into this 
register. When RS and CS are LOW, 
the address is selected. 


HORIZONTAL TOTAL REGISTER (R0) 
This 8-bit register is used to program 
the total number of horizontal charac- 
ters per line, including the retrace 
period. The data value should be 
programmed according to the specifica- 
tion of the CRT. When M is the total 
number of characters, (M-1) must be 
programmed into this register. When 
programming for interlace mode, M 
must be even. 


HORIZONTAL DISPLAYED 
REGISTER (R1) 
This 8-bit register is used to program 
the number of horizontal displayed 
characters per line. Any 8-bit number 
that is smaller than that of horizontal 
total register contents can be pro- 
grammed. 


HORIZONTAL SYNC POSITION 
REGISTER (R2) 
This 8-bit register is used to program 
horizontal sync position as multiples of 
the character clock period. Any 8-bit 
number that is lower than the horizontal 
total register contents can be pro- 
grammed. When H is the character 
number of the horizontal sync position, 
(H-1) must be programmed into this 
register. When the programmed value 


Table 4 Addltlonal Notes: 
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of this register is increased, the display 
position on the CRT screen is shifted to 
the left. When the programmed value is 
decreased, the position is shifted to the 
right. Therefore, the optimum horizontal 
position can be determined by this 
value. 


SYNC WIDTT-I REGISTER (R3) 
This 8-bit register is used to program 
the horizontal sync (HS) pulse width 
and the vertical sync (VS) pulse width. 
The horizontal sync pulse width is 
programmed in the lower four-bits as 
multiples of the character clock period 
(see Table 5); a zero cannot be 
programmed. The vertical sync pulse 
width is programmed in the higher four 
bits as multiples of the raster period 
(see Table 6). When zeroes are 
programmed in the higher four bits, a 
16-raster period is specified. 


VERTICAL TOTAL REGISTER (R4) 
This 7-bit register is used to program 
the total number of lines per frame, 
including vertical retrace period. The 
data and its value should be pro- 
grammed according to the specification 
of the CRTC. When N is the total 
number of lines, (N-1) must be pro- 
grammed into this register. 


VERTICAL TOTAL ADJUST 
REGISTER (R5) 
This 5-bit register is used to program 
the optimum number to adjust the total 
number of rasters per field. This 
register enables more precise control of 
the deflection frequency. 


VERTICAL DISPLAYED REGISTER 
(F16) 
This 7-bit register is used to program 
the number of displayed character rows 
on the CRT screen. Any 7-bit number 


1. The registers marked‘: (written value) = (specified value) -1 
2. Written value of R9: 


VL68C45R/S 


that is smaller than that of vertical total 
register contents can be programmed. 


VER11CAL SYNC POSITION 
REGISTER (R7) 
This 7-bit register is used to program 
the vertical sync position on the screen 
as multiples of the horizontal character 
line period. Any number that is equal to 
or less than the vertical total register 
content can be programmed. When V 
is the character number of vertical sync 
position, (V-1) must be programmed to 
this register. When programmed value 
of this register is increased, the display 
position is shifted up. When the 
programmed value is decreased, the 
position is shifted down. Therefore, the 
optimum vertical position may be 
determined by this value. 


INTERLACE AND SKEW REGISTER 
(R3) 
This register is used to program raster 
scan mode and skew (delay) of the 
Cursor signal and Display Enable 
signals. 


INTERLACE MODE PROGRAM BITS 
(V,$) 
Raster scan mode is programmed (see 
Table 7) by the V and S bits of R8. In 
the non-interlace mode, duplicate 
scanning is done of the rasters of even 
number field and odd number field. In 
the interlace sync mode, the rasters of 
the odd number field are scanned in the 
middle of the even number field. The 
same character pattern is then dis- 
played in two fields. In the interlace 
sync and video mode, the raster scan 
method is the same as in the interlace 
sync mode, but it is controlled to display 
different character patterns in two fields. 


a) Non-lnterlace mode and interlace Sync Mode (written value Nr) = (specified value) -1 
b) lnterlace sync and video mode: (Written value Nr) = (specified value) -2 
3. CO and C1 specify skew of CURSOR output signal. DO and D1 specify skew of Display Enable output signal. 
When S is 
one, V specifies video mode. S specifies the interlace sync mode. 
4. B specifies cursor blink. 
P specifies the cursor blink period. 
5. wvO~wv3 specify the pulse width of the vertical sync signal. wh0 ~wh3 specify the pulse width of the horizontal sync signal. 
6. R0 is normally programmed to be an odd number in interlace mode. 
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VL68C45S 
REGISTER FILE DESCRIPTIONS (Cont.) 


TABLE 5: PULSE WIDTH OF HORIZONTAL SYNC SIGNAL 


VSW/HSW Register (R3) 
HSW Pulse Width 
Bit3 
Bit2 
; BIt1 
BitO 
(multiples of char clock period) 


__ 
_ 
‘ 
_ 
_ 
I 
___ 
_ 
_ 
__ 
W 
0 
_o 
0 
_ 
g 
NotAllowed 
C 


H 
0 
go 
1,. 
1 
O 


O 
O 
_L 
O 
. 
2 


_ 
_ 
iii 
I 
____ 
-4- 
_ 


Q 
Q 
-A 
-A 
(A) 


Q 
-A 
Q 
Q 
Q 
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' 
_ 
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,_ 
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__ 
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-L 
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O’) 
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_ 
‘ 
__ 
_ 
__ 
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-A 
-A 
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-L 
O 
O 
O 
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l 


1 
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Q 
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___ 
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T 
__ 
L 
, 
__ 
I 
EH1 
130 
-L 
Q 
-L 
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, 
L 
__ 
_ 
I 
'7 
___ 
11 
-L 
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1K 
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, 
12,, 


_L 
_L 
O 
O 


-A 
-A 
Q 
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TABLE 1; INTERLACE MODE B|Ts 
(BITS 1 AND 0 of R8) 
v 
s 
I 
Bit1 
Bit2 
Mode 


T0 
I 
0 
Normal Sync Modej 
1”, 
0 
(Non-interlace) 
T 


lnterlace Sync Mode 
O 


interlace Sync and 


\ 
Video Mode 


Q 
-i 


SKEW PROGRAM BITS 
(C1,C0,D1,DO) 
These bits are used to program the 
skew (delay) of the Cursor and Display 
Enable signals. 


_ 
_ 
Skew of these two kinds of signals is 


-L 
-L 
-A 
Q 
l 
1 4 
T 
if 
' 
3 
15 
—L 
—L 
Q-L 
-5 


TABLE 6: PULSEWIDTH OF VERTICAL SYNC SIGNAL 
vsw/Hsw Registerrrm 
If 
VSWPulseWidth 
Bit 7 
Bit 6 
Bit 5 
\ 
Bit 4 
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(I‘l1LIIIIpI8S OI T8819! p6I’IOd) 
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programmed separately. The skew 
function is used to provide an on-chip 
delay for the output timing of the Cursor 
and Display Enable Signals to provide 
the time required to access refresh 
memory, character generator or pattern 
generator, and to ensure that they are 
TABLE a; DISPLAY ENABLE SKEW 
BIT (BITS 5 AND 4 OF R8) 
K 
_ 


D1 
D0 
Bit 5 
I Bit 4 
Display Enable Signal 


T 
0 
0 
,Non-Skew 
W 


0 
1 
T 
One-characterSkew M 
T 


1 
1"'*' 
' 
' 
V’ 
' 


A 
fg 
l 
Two-character_Skew 
i 
-A 
O 


Non-output 
T 
T 
é 
—L 


TABLE 9: cunson SKEW BITS 
(BITS 7 & 6 o|= R8) 
W 
K 
_ 
c1 
co 
1 
Bit7 
, Bit6 
A DisplaySkew 


0 
0 
_g Non-Skew 


0 
1 
, One-character Skew 


éi 
-o 


Two-character Skew 


y Non-output 
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VL68C45S REGISTER FILE 
DESCRIPTIONS (Cont.) 
in phase with the serial video signal. 
MAXIMUM RASTER ADDRESS 
REGISTER (R9) 
This 5-bit register is used to program 
the Maximum Raster Address. This 
register defines total number of rasters 
per character, including space. 


This register is programmed as follows: 
1. Non-lnterlace Mode, 
lnterlace Sync Mode: When the total 
number of rasters is RN, (RN-1) 
must be programmed. 


2. lnterlace Sync and Video Mode: 
When total number of rasters is RN, 
(RN-2) must be programmed. 


The total number of rasters in non- 
interlace mode, interlace sync mode 
and interlace sync and video: mode is 
TABLE 10: 
RASTER COUNT IN 
INTERLACE AND 
NON-INTERLACE MODES 


0 
e 
Total number of rasters 5 


1 
. 
5 
_ Programmed value Nr = 4 


2 . 
5 
e 
_ (The same as displayed 
total number of rasters) 


3 


4 I. 
W 
L 


Raster Address 


INTERLACE SYNC MODE 


0 
. 
- 
Total number of rasters 5 
--------- - - 0 programmed value 
Nr=4 


In the interlace sync 
mode, total number of 
_________ _ _ 1 rasters in both the 
2 L 
L 
even and odd fields is 
ten. On programming, 
the halt of it is defined 
_ 
-:- 
-2 


3 ~ 
~ 
A 
as total number of 
_________ _. _ 3 rasters. 


4 
. 
--------- - - 4 


Raster Address 


INTERLACE SYNC AND VIDEO MODE 


0 
. 
. 
Total Number of Rasters 5 
--------- — — 1 Programmed Value 
Nr = 3 


2 
L 
(Total number of 
_________ _ _ 3 rasters displayed in 
the even field and the 
4 
. 
odd field) 


Raster Address 


defined as follows in Table 10. 


CURSOR START RASTER REGISTER 
(R10) 
This 7-bit register is used to program 
the cursor start raster address and the 
cursor display mode. The lower five 
bits program the raster address and the 
higher two bits program the display 
mode (see table 11). 
TABLE 11: cunson DISPLAY 
MODE (BITS 6 AND 5 OF R10) 


I 
-I 
I____I___"' 
*7"l 
r 
B‘P 
Blt6 
, Blt5 
Cursor Dlsplayhllode 
0 
I 
0 
‘Non-Blink 


__ 
__ 
_ '_" 
ri 


I 
-_ 
_- 
I 
_ 
_ 
' 
_ 
' 
'7" 
7' 
0 
. 
1 
iCursorNon-Display 


, Blink,*1/1SField Rate 
-5 
O 


—L 
é 
Q 
; Blink, 1/32 Field Rate M 


Note: 
The blink sequence is follows: 


| 
Light 
| 
Darkl 


(16 x or 32 x the field period) 


CURSER END RASTER REGISTER 
(R11) 
This register is used to program the 
cursor end raster address. 


START ADDRESS REGISTER 
(R12,R13) 
This register pair is used to program the 
first address of refresh memory read 
out. Paging and scrolling are easily 
performed using this register. This 
register can be read but the higher 2- 
bits of R12 are always zero. 


CURSOR REGISTER (R14, R15) 
These two read/write registers store the 
cursor location. The higher 2 bits of 
R14 are zero. 


LIGHT PEN REGISTER (R16, R17) 
These read-only registers are used to 
capture the detection address of the 
light pen. The higher 2 bits of R16 are 
always zero. The value of R16 and R17 
needs to be corrected by software 
because there is a time delay from the 
address output by the CRTC to the 
signal input to its LPSTB pin that the 


light pen detects. 


CONSIDERATIONS IN UPDATING 
REGISTERS 
The value programmed into the internal 
registers directly controls the CRT. 
Consequently, the display may flicker 
on the screen when the contents of the 
registers are changed from the bus side 
asynchronously with display operation. 


RESTRICTTONS ON PROGRAMMING 
INTERNAL REGISTERS 
1.05 Nhd 5 Nht-l-15256 
2.05Nvd5Nvt+15128 
3. 0 5 Nhsp 5Nht 
4. 0 5Nvsp 5 Nvt, Note 1 
5. O 5 NCSTART 5 NCEND 5 Nr (non- 
interlace, interlace sync mode) 
0,NCSTART 5 NCEND 5 Nr +1 
(interlace and video mode) 
6. 2 5 Nr 5 30 
7. 3 5 Nht (except non-interlace mode) 
5 5 Nht (non-interlace mode only) 


UPDATING THE CURSOR REGISTER 
Writing into this register at frequent 
intervals for moving the cursor should 
be performed during horizontal and 
vertical retrace periods. 


UPDATING THE START ADDRESS 
REGISTER 
Writing into the start address register at 
frequent intervals for scrolling and 
paging should be performed during 
horizontal and vertical display periods. 


It is desirable to avoid programming any 
registers besides the cursor and Start 
Address Register during display 
operations. 


In the interlace mode, pulse width is changed + 1/2 raster time when vertical sync signal extends over two fields. 
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VL68C45 CHARACTERISTICS 
SYSTEM DIAGRAM 


VIDEO TIMING CONTROL 
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TABLE 12. CRTC BUS TIMING CHARACTERISTICS 


VL68C45R-35 
VL68C45S-35 
VL68C45R-36 
VL68C45S-36 
VL68C45R-38 
VL68C45S-38 
VL68C45R-23 
VL68C45S-23 


Symbol 
Parameter 
U"|t 
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FIGURE 2. BUS TIMING 
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TABLE 13. CRTC VIDEO TIMING CHARACTERISTICS 


Symbol 
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FIGURE 3. VIDEO TIMING 
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TABLE 14. CRTC LIGHT PEN TIMING CHARACTERISTICS 


FIGURE 4; LIGHT PEN 11MlNG 
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VL68C45R-35 
VL68C45S-35 
VL68C45R-36 
VL68C45S-36 
VL68C45R-38 
VL68C45S-38 


Symbol 
Parameter 
Unlt 
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Light Pen Display Time 2 
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ABSOLUTE MAXIMUM RATINGS 
Ambient Operating 
Stresses above those listed under 
any other conditions above those 
Temperature 
0°C to 70°C 
"Absolute Maximum Ratings" may cause 
indicated on the operational sections oi 
Storage Temperature 
455°C to 150°C 
permanent damage to the device. 
this specification is not implied and 
These are stress ratings only. Func- 
exposure to conditions for extended 
SUPPIY Voltage 10 
tional operation of this device at these or 
periods may affect device reliability. 
Ground Potential 
-0.3 to +7.0 V 


Applied Voltage 
-0.3 to +7.0 V 


DC CHARACTERISTICS TA = 0°C to 70°C VCC = i5% unless otherwise s - ecllled 
Symbol 
Parameter 
T 
Condltlons 


VIH 
Input High Voltage 
VCC 


u 
. 


. 
>¢Q_ y 


co 


‘O 


VIL 
Input Low Voltage 
"N 
Input Leakage Current 
R/-W RES RS CS LPSTB CCLK Q2 


Input Leakage Current for Three State Off 
VIN -= 0.4 V to 2.4 V 
ITS‘ 
DBO 
DB7 
* 
“A 
vcc - 5.25 v 


VOH 
Output High Voltage 
ILOAD = -205 i1A (DBO - DB7) 
ILOAD = -100 pA (All Others) 


VOL 
Output Low Volta e 
ILOAD 
1 6 m 


ICC 
Input Power Supply Current 
mA/MHZ 


Cl 
Input Capacitance 
O2 R/-W RES CS RS LPSTB CLK 
DBO 
DB7 


C0 
Output Capacitance 
pF 
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FEATURES 
- FSK and PSK modulators and 
demodulators, high-band and low- 
band filters with compromise ampli- 
tude and group delay equalizers 


- Built-in call progress mode and tone 
generators for DTMF V.21 and V.22 
guard tones 


- Bell 212A and CCITT V.21 and V.22 
compatible; V.22 notch filters included 


- Serial control interface 


- Programmable audio output port 


- Analog, digital, and remote digital 
loopback capabilities 


- 24-pin DIP and 28-pin plastic 
leaded chip carrier available 


VL7C21 2A 


300/1200 BIT-PER-SECOND MODEM 


DESCRIPTION 
The VL7C212A is a complete 300/1200 
bit-per-second modem. All of the signal 
processing functions needed for a full 
duplex, 300/1200 bit-per-second 212A 
(V.21 or V.22) modem, including both 
FSK and PSK modulators and demodu- 
lators and the high-band and low-band 
filters, are integrated on a single chip. It 
is built using a three-micron CMOS 
double-polysilioon process that allows 
analog and digital functions to be 
combined on the same chip. This design 
includes capabilities for progress 
monitoring and for generating DTMF as 
well as V.21 or V.22 guard tones. The 
two-to-four wire hybrid is also included, 
simplifying the interface to a DAA. The 
VL7C212A also includes analog 
loopback and remote digital loopback 
functions for sell-testing. 


High level of integration provides a 
highly cost effective 300/1200 bit- 
per- second modems 


Eliminates external components, 
easing design of intelligent modems 


Usable in North American and 
European modem designs 


Simple board layout 


Simple speaker interface for monitor- 
ing phone line 


Testable signal path 


Reduced board area 


Direct replacement for Sierra 
SC11004 and SC11014 


PIN DIAGRAMS 
BLOCK DIAGRAM 


VL7C21 2A-PC 


AGND I 
1 
24 I 
TXCKO I 2 
23 I 
TXCK1 I 3 
22 I 
TEST1 I 
4 
21 I 
TEST2 I 
5 
20 I 
RXCK I 
6 
19 I 
AUDIOOUT I 7 
18 I 
N.C. I 8 
17 I 
RXA1 I 
9 
16 I 
RXA2 I 
10 
15 I 
TXOUT I 
11 
14 I 
VSS I 
12 
13 I 


vcc 
CKOUT 
oeuo 
XTAL2 
XTAL1 i 
N.C. 
-we 
-no 
SCK 
0 I/O 
1x0 
nxo 


VL7C21 2A-QC 


TXCKO N.C. CKOUT 
TXCK1 AGND VCC 
DGND 
I I I I I I I 


4 
3 21282726 
TEST1 I 
5 
' 
25 I 
XTAL2 


N.C. I 
6 
24 I 
XTAL1 
TEST2 I 
7 
23 I 
N.C. 


RXCK I 
8 
22 I 
-WR 
AUDIO OUT I 
9 
21 I 
N.C. 


N.C. I 
10 
20 I 
-RD 


RXA1 I 
11 
19 I 
SCK 
12131415161718 


RXA2 VSS 
TXD 
N.C. 
TXOUT RXD 
DIIO 


TXD 
ASYNCI 
PSK 
SYNC 
$°""""BLE" 
MODULATOR 
MU; 
AND 
FSK 
PREFILTER 
DULATOR 


NOTCH 
LOW-BAND 
F||_TER 
FILTER 


HIGH-BAND 
V 
FILTER 


ENERGY 
|\|sMrT 
HYBRID 
. mim; 
°EIE°T°" 
AND ANTI 
FILTER mo 
ALIASING 
LEVEL ADJ 
a 


=-I 


garEl 
I3 
I“ii 
asy3IliAv? 


TXOUT 
RXA1 


RXA2 


AUDIO 
OUT 


RXD 
SYNC! 
ASYNC 


D V0 
RXCK 
UNSCRAMBLED 
SCK 
V0 
MARK DETECTOR 
Ur 
OKO 
-"D 
INTFI 
XTAL1 


XTAL2 


TXCKO 


TXCK1 


-WR 
DEOODER 
V.22 GUARD 
CLOCK 
TONE AND 
GENERATOR 
DTMF 
GENERATOR 


ORDER INFORMATION 


Part 
_ 
Number 
Package 


VL7C212A-PC 
Plastic DIP 
_ 
VL7C212A-QC 
Plastic Leaded Chip Carrier (PLCC) 


Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL DESCRIPTIONS 


Pln 
Number (Note) 
Slgnal 
Name 


TXD 
14 


RXD 
13 


D I/O 
15 


-WR 


-RD 


SCK 


18 


17 


16 


TXOUT 
11 


RXA1, RXA2 
9, 10 


AUDIO OUT 
7 


XTAL1 , XTAL 
20, 21 


CKOUT 
23 


TXCKO 
2 


TXCK1 
3 


RXCK 
6 


VCC 


VSS 


DGND 
22 


AGND 
1 


TEST1, 2 
4,5 


N.C. 
8, 19 


24 


12 
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Slgnal 
Descrlptlon 


Transmit Data- Data on this input is modulated by the modem and output on TXOUT pin. 
A logic low is space and a logic high is mark. 


Receive data- The modem demodulates the received carrier and outputs data on this pin. 
A logic low level is space and a logic high level is mark. The controller can force the 
demodulator output to the mark state by sending the code O2. 


Data l/O- Data is shifted in serially when WR is low on rising edges of SCK clock. Data is 
transferred to a latch when WR goes high. Up to seven data bits can be sent. Input 
codes are defined in Table 1. Data is read from the modem serially when RD is low, on 
rising edges of SCK clock. Up to four data bits can be read. Output codes are defined in 
Table 1. 


Strobe output from the controller for shifting data to the modem. 


Strobe output from the controller for serially reading data from the modem. 


Serial shift clock is applied to this pin. It is normally high until data is sent to, or read 
from, the modem. 


Transmit data carrier output. 


Received data carriers. 


Output of the hybrid is passed through a programmable attenuator and brought out on 
this pin. Four levels of received signal can be programmed using the control codes listed 
in Table 1. 


Pins for connecting a 7.3728 MHz crystal. An external clock signal can be applied to the 
XTAL1 pin. 


Buffered crystal oscillator signal is output on this pin. It can drive one LS TTL load. 


Transmitter Clock Output- In high speed, synchronous internal mode, this output supplies 
a 1200 Hz clock to the DTE. 


In high speed, synchronous external mode this pin is an input for receiving a 1200 Hz 
clock from the DTE. 


Receiver Clock Output- In high speed, synchronous, external mode, the modem supplies 
a 1200 Hz clock on this output. 


+ 5 V power supply. 
- 5 V power supply. 


Digital ground. 


Analog ground. 


Used by VLSI for testing. Make no connection to these pins. They must be left floating. 


No Connect- No internal connection is made to these pins and they may be left floating. 


Note: Pin numbers refer to the DIP package. 
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FUNCTIONAL 
DESCRIPTION 
With the addition of a digital controller, 
such as an 8-bit microcontroller and a 
data access arrangement (DAA), a 
highly cost effective, integrated, intelli- 
gent modem can be built. When used 
with the VLSI VL7C213A modem 
controller, which is an 8-bit processor 
combined with a UART, a complete 
Hayes command set compatible modem 
can be configured, taking up a minimum 
of board area. For stand-alone applica- 
tions, the VL7C212A modem, the 
VL7C213 controller, a DAA and an 
RS232-interface are all that are required. 


The VL7C212A is truly a modem on a 
chip. All of the signal processing 
functions needed for a full duplex, 300/ 
1200 bps Bell 212A or CCITT V.21 or 
V.22 modem are integrated on a single 
chip. It operates in a synchronous or 
asynchronous mode and handles 8, 9, 
10, or 11 bit words. 


Like all modems, the VL7C212A needs a 
controller to determine the mode of 
operation, initiate the call to the remote 
modem (either pulse or tone dialing), set 
up the handshaking sequence with the 
remote modem, monitor the call progress 
tones on the line (ringing, busy, answer 
tone, and voice) and switch into the data 
mode. A simple four-line serial data 
interlace was designed for the 
VL7C212A, enabling it to work with just 
about any 8-bit microcontroller or 
microprocessor. The control lines are: 
DATA INPUT/OUTPUT, SHIFT CLOCK, 
READ and WRITE. 


MODEM 
Major sections of the VL7C212A modem 
are a transmitter, a receiver, low-band 
and high-band filters, a two-to-four wire 
hybrid, tone generators and interface 
logic. It also contains an energy detector 
that's used for detecting the carrier and 
call progress monitoring and an audio 
output for monitoring the line. 


The VL7C212A modem requires plus 
and minus five volts and is available in a 
24-pin DIP as well as a 28-pin plastic 
chip carrier with "J" leads for surface 
mount applications. The transmitter 
section consists of an async/sync 
converter, scrambler, PSK modulator. 
and FSK modulator. In the high speed 
mode (1200 bps), the PSK modulator is 
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connected to the filter. In the low speed 
mode (300 bps), the FSK modulator is 
connected to the filter. 


TRANSMITTER 
Since data terminals and computers 
may not have the timing accuracy 
required for 1200 bps transmission 
(0.01%), timing correction on the 
incoming data stream must be made. 
The async/sync converter accepts 
asynchronous serial data clocked at a 
rate between 1200 Hz + 1%, -2.5%. It 
outputs serial data at a fixed rate of 
1200 Hz +/- 0.01% derived from the 
master clock oscillator. To compensate 
for the input and output rate differences, 
a stop bit is either deleted or inserted 
when necessary. If the input data rate is 
slower than the output data rate, a stop 
bit is inserted. If the input data rate is 
faster than the output data rate, a stop 
bit is deleted. The output of the asyncl 
sync converter is applied to the scram- 
bler. 


The scrambler is a 17-bit shift register 
clocked at 1200 Hz. Outputs from the 
14th and 17th stages are exclusive OR'd 
and further exclusive OR'd with the input 
data. The resultant data is supplied to 
the D input of the shift register. Outputs 
from the first two stages of the shift 
register form the dibit that is applied to 
the PSK modulator. The purpose of the 
scrambler is to randomize data so that 
the energy of the modulated carrier is 
spread over the band of interest. The 
high-band being centered at 2400 Hz or 
the low-band, centered at 1200 Hz. A 
1200 bps modem actually sends two bits 
at a time, called a dibit; dibits are sent at 
600 baud, the actual rate of transmis- 
sicn; 600 baud is the optimum rate that 
can be transmitted over the general 
switched telephone network for a full 
duplex FDM (frequency division multi- 
plexing) modem because band limit 
filters in the central office cut off at about 
3000 Hz. 


The dibit applied to the PSK modulator 
produces one of four differential phase 
shifts of the square wave carrier signal 
(1200 Hz or 2400 Hz) at the 600 Hz 
baud rate. The resultant waveform is 
passed through a wave shaping circuit 
that performs a raised cosine function 
(this is the shape factor called out in the 
CCITT V.21 and V.22 specifications, 


VL7C212A 


and it also meets the Bell 212A require- 
ment for optimum transmission). The 
wave shaped signal is then passed 
through either the low-band or high- 
band filterdepending upon originate or 
answer mode selection. 


For low speed operation the FSK 
modulator is used. It produces one of 
four precision frequencies depending on 
originate or answer mode and the 1 
(mark) or 0 (space) level of the transmit 
data. The frequencies are produced 
from the master clock oscillator using 
programmable dividers. The dividers 
respond quickly to data changes, 
introducing negligible bit jitter while 
maintaining phase coherence. The 
output of the FSK modulator is applied 
to the appropriate filter when the low 
speed mode of the operation is selected. 


The filter section consists of low-band 
(1200 Hz) and high-band (2400 Hz) 
filters, half-channel compromise 
amplitude and group delay equalizers 
for both bands, smoothing filters for both 
bands and multiplexers for routing of the 
transmit and receive signals through the 
appropriate band filters. For CCITT 
V.21 or V.22 applications, a notch filter 
is included that can be programmed for 
either 550 Hz or 1800 Hz. In the call 
progress monitor mode, the low-band 
filter is scaled down by a factor of 2.5 to 
center it over a frequency range of 300 
to 660 Hz. Thus, during call establish- 
ment in the originate mode, call prog- 
ress tones can be monitored through the 
scaled low-band filter and the modem 
answer tone or voice can be monitored 
through the unscaled high-band filter. 


The low-band filter is a 10th order 
switched-capacitor band-pass filter with 
a center frequency of 1200 Hz. In the 
originate mode, this filter is used in the 
transmit direction; in the answer mode it 
is used in the receive direction. When 
analog loopback is used in the originate 
mode, this filter, together with the low- 
band delay equalizer, is in the test loop. 
In the call progress monitoring mode the 
filter response is scaled down by 2.5, 
moving the center frequency to 480 Hz. 


The low-band delay equalizer is a 10th 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the low-band filter and half of 
the compromise line characteristics, 
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producing a flat delay response within 
the pass-band. 


The high-band filter is a 10th order 
switched-capacitor band-pass filter with 
a center frequency of 2400 Hz. In the 
answer mode, this filter is used in the 
transmit direction; in the originate mode, 
it is used in the receive direction. When 
analog loopback is used in the answer 
mode, this filter, together with the high- 
band delay equalizer, will be in the test 
loop. 


The high-band delay equalizer is a 10th 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the high-band filter and half 
of the compromise line characteristics, 
producing a flat delay response within 
the pass-band. The transmit smoothing 
filter is a second order low-pass 
switched-capacitor filter that adds the 
modem transmit signal to the DTMF 
(V.21 or V.22) guard tones. It also 
provides a 3 dB per step programmable 
gain function to set the output level. 


RECEIVER 
The receiver section consists ofan 
energy detector, AGC, PSK demodula- 
tor, FSK demodulator, descrambler, and 
sync/async converter. 


The received signal is routed through 
the appropriate band-pass filter and 
applied to both the energy detector and 
AGC circuit. The energy detector is 
based on a peak detection algorithm. It 
provides a detection within 17 to 24 ms. 
It is set to turn on when the signal 
exceeds -43 dBm and turn off when the 
signal falls below -48 dBm. A 2 dB 
minimum hysteresis is provided between 
the turn on and turn off levels. 


The AGC circuit is a programmable gain 
amplifier that covers a range of 28 dB in 
seven steps. The gain is controlled by a 
3 bit up/down counter. Output of the 
AGC amplifier is rectified and compared 
with two preset levels corresponding to 
desired high and low limits. Outputs of 
the comparators control the up/down 
counter such that the received signal is 
amplified to the desired level. 


The PSK demodulator uses a coherent 
demodulation technique. Output of the 
AGC amplifier is applied to a dual phase 
splitter that produces an in-phase and 
90 degree out of phase component. 
These components are then demodu- 


lated to baseband in a mixer stage 
where individual components are 
multiplied by the recovered carrier. The 
baseband components are low-pass 
filtered to produce I and Q (In-phase and 
Quadrature) channel outputs. The I and 
O channel outputs are rectified, 
summed, and passed through a band- 
pass filter giving a 600 Hz signal. This 
signal is applied to a digital phase lock 
loop (DPLL) to produce a baud rate 
clock. Using the recovered clock signal, 
the I and Q channels are sampled to 
produce the received dibit data. The 
recovered carrier for the demodulator is 
generated by another PLL which is 
controlled by the amplitude of the error 
signal formed by the difference of the I 
and Q outputs. 


The descrambler is similar to the 
scrambler. The received dibit data is 
applied to the D input of a 17 bit shift 
register clocked at 1200 Hz. Outputs 
from the 14th and 17th stages are 
exclusive OR'd and further exclusive 
OR'd with input data to produce received 
data. 


In the asynchronous mode, data from 
the descrambler is applied to the syncl 
async converter to reconstruct the. 
originally transmitted asynchronous 
data. For data which had stop bits 
deleted at the transmitter (overspeed 
data), these stop bits are reinserted. 
Underspeed data is passed essentially 
unchanged. 
Output of the sync/async 
converter along with the output of the 
FSK demodulator is applied to a 
multiplexer. The multiplexer selects the 
appropriate output, depending on the 
operating speed, and outputs received 
data on the RXD pin. 


For low speed operation, the FSK 
demodulator is used. The output of the 
AGC amplifier is passed through a zero 
crossing detector and applied to a 
counter that is reset on zero crossings. 
The counter is designed to cycle at a 
rate four times faster than the carrier 
signal. The counter output is low-pass 
filtered and hard limited to generate FSK 
data. 


HYBRID 
' 
The signal on the phone line is the sum 
of the transmit and receive signals. The 
hybrid subtracts the transmitted signal 
from the signal on the line to form the 
received signal. It is important to match 


the hybrid impedance as closely as 
possible to the telephone line to produce 
only the received signal. This matching 
provided by an external resistor con- 
nected between the RXA1 and RXA2 
pins on the VL7C212A. The filter 
section provides sufficient attenuation of 
the out of band signals to eliminate 
leftover transmit signals from the 
received signal. The hybrid also acts as 
a first order low-pass antialiasing filter. 


TONE GENERATOR 
The tone generator section consists of a 
DTMF generator and a V.21 (or V.22) 
guard tone generator. The DTMF 
generator produces all of the tones 
corresponding to digits 0 through 9 and ‘ 
and # keys. The V.21 (or V.22) guard 
tone generator produces either 550 Hz 
or 1800 Hz. Selection of either the 550 
Hz or 1800 Hz tone will cascade the 
corresponding notch filter with the low- 
band filter. The tones are selected by 
applying appropriate codes through the 
Data I/O pin. Before a tone can be 
generated, tone mode must be selected. 
Facility is also provided to generate 
single tones corresponding to the 
individual rows or column of the DTMF 
signal. 


AUDIO OUTPUT STAGE 
A programmable attenuator that can 
drive a load impedance of 50 KQ is 
provided to allow monitoring of the 
received line signal through an external 
speaker. The attenuator is connected to 
the output of the hybrid. Four levels of 
attenuation: no attenuation, 6 dB 
attenuation, 12 dB attenuation and 
squelch are prOVId8d through the ALC1, 
ALCO and audio output level control 
codes. Output of the attenuator is 
available on the audio output pin where 
an external audio amplifier (LM386 type) 
can be connected to drive a low 
impedance speaker. The output can 
directly drive a high impedance 
transducer, but the volume level will be 
low. 


VL7C213 AND VL7C214 
CONTROLLERS 
The VL7C213 modem controller, 
implemented in VLSl's two-micron 
CMOS process, was designed specifi- 
cally to handle all of the modem control 
functions, as well as the interface to a 
system bus. Besides including an 8-bit 
microprocessor, 8K by 8 bytes of ROM, 
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and 128 by 8 bytes of RAM, it also 
contains the functionality of a VL82C50 
UART, greatly simplifying the interface 
to a parallel system bus, such as used in 
an IBM PC-compatible personal 
computer (PC). In fact, a complete, 
Hayes compatible modem for the PC 
consists of the VL7C213 controller, the 
VL7C212A modem and the DAA. All of 
the popular communications software 
written for the PC will work with the 
VL7C212A/VL7C213 set. 


Another version of the controller, the 
VL7C214, is intended for RS-232 
applications. It contains the same 
processor, memory, and UART as the 
VL7C213 and has the same interface to 
the modem chip. The difference is that 
the UART is turned around so that serial 
data from the RS-232 port is converted 
to parallel data handled by the internal 
processor. Pins are provided for 
connecting the familiar switches and 
indicator lamps found on most stand- 
alone modems, although the switches 
and lamps are not needed for operation. 
All of the switch settings can be done 
through software. 


The VL7C214 provides a standard five 
volt logic level interface. RS-232 drivers 
are required to interface to the port. 
Like the VL7C213, the VL7C214 comes 
preprogrammed with the Hayes "AT" 
command set, and when used with the 
VL7C212A modem, emulates a Hayes- 
type stand-alone modem. The VL7C213 
and VL7C212A emulate a Hayes-type 
IBM PC plug-in card modem. But the 
chip set is by no means limited to 
implementing a Hayes-type smart 
modem. VLSI is in the custom IC 
business and both chips were designed 
with this in mind. For example, only 
about 6K bytes of the VL7C213's ROM 
is used for the handshaking and smart 
modem code, leaving 2K bytes for 
additional features that a customer may 
specify. Since the controller is ROM 
programmable, any command set, not 
just the Hayes "AT" set, can be imple- 
mented. 


Both the VL7C213 and VL7C214 require 
plus five volts and are available in either 
a 28-pin DIP or a 28-pin plastic chip 
carrier with "J" leads for surface mount 
applications. Besides the four-line 
interface for the VL7C212A modem, the 


VL7C213 controller has an 8-bit data 
port, three address lines, a chip select 
input, an interrupt line, and the DOST 
and DIST control lines found in the 
8250B UART. It also has control lines 
for ring indication, the off-hook relay and 
a data/voice relay; these three lines 
connect to the DAA. 


In the VL7C214, the 8-bit port becomes 
the switch input lines and the address, 
chip select, DIST and DOST lines 
become the six lines for the RS-232 
interface. These six lines are also used 
to drive the LEDs. Internally, all of these 
lines are treated as programmable I/O 
ports under software control. The 
primary difference between the 
VL7C213 and VL7C214 is the ROM 
code. It also contains the same modem 
and DAA interface lines as the 
VL7C213. 


The VL7C213 and VL7C214 are truly 
ASIC controllers. They are designed to 
control a modem or other peripheral that 
operates at a moderately slow data rate 
up to 1200 bits per second. The 
VL7C213 allows a slow peripheral to 
interface to a high speed bus, without 
making the main processor slow down. 


This" is done through the UART interface 
and the on-chip registers which look 
somewhat like dual port registers. The 
main processor can write to and read 
from them at will, while the on-chip 
controller can do the same. The 
controller was designed this way 
because most communication software 
has to have unrestrained access to the 
UART registers. To make the VL7C213 
compatible with this software, the 
registers were included. 


The internal processor monitors the 
registers to determine the mode of 
operation. Command mode or data 
mode: at power-up it is automatically put 
in the command mode and it looks for- 
instructions. Once carrier is detected, it 
goes into the data mode, and stays 
there until escape sequence is three "+" 
signs (+++) in the default mode, but it 
can be changed in software. 


The actual processor contains an 8-bit 
data path and can execute 19 instruc- 
tions with five different addressing 
modes: direct, indirect, immediate, 
register direct, and register indirect. 
There is 8K by 8 of ROM on-chip for 


program SIOTBQB. 


To the system bus, the VL7C213 looks 
and acts just like a VL82C50 UART. All 
of the communications software written 
for this UART will work with the 
VL7C213 and VL7C214. The VLSI chip 
set is a Hayes-type modem in two chips. 


The VL7C21 2A AND 
VL7C213NL7C214 System 
The only external components required 
by the VL7C212A are the 600 Q line 
matching resistor, a 7.3728 MHz crystal 
(a standard frequency) and a 20 pF 
capacitor from each leg of the crystal to 
ground. That's alll If it is desired to drive 
a speakerto monitorthe line, an 
amplifier like the LM386 can be added, 
but the output provided on the 
VL7C212A can directly drive a high 
impedance (50 kQ) earphone-type 
transducer. 


The VL7C213 modem controller's clock 
in line is driven by the VL7C212A's clock 
out line, so only one crystal is needed. 
The VL7C213 interfaces directly to an 
IBM PC bus - no buffers are required. 
The only external parts may be an eight 
input NAND gate for COM1 and COM2 
decoding inside the PC. 


For tone dialing, the controller sends a 
code to the modem chip which in turn 
puts out the called for DTMF tone on the 
line via the on-chip DTMF generator. 
For pulse dialing, the controller pulses 
the OH (off-hook) relay. Both dialing 
modes work with the built-in call 
progress algorithm so they won't start 
dialing until a dial tone is detected. 


All modems require a DAA. A DAA 
(data access arrangement) is a piece of 
equipment required by the FCC to 
connect anything to the general 
switched telephone network. It consists 
of an isolation transformer, typically 600 
Q to 600 Q; a relay for disconnecting 
the modem from the line; a ring detector, 
typically an opto-isolator; and high 
voltage surge protectors. The DAA has 
to be FCC registered and this can be 
done by any of many consultants and 
labs around the country. Another 
alternative is to buy a DAA, supplied by 
several manufacturers. 


212A is a Bell specification that calls for 
1200 bit per second, full or half duplex 
data transmission with a fallback mode 
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of 300 baud (Bell 103). It is not 1200 
baud; the spec calls for transmission of 
dibits, or 2 bits per baud so the 1200 
bps transmission takes place at 600 
baud. The same is true for V.22; it's 
1200 bps or 600 baud. V.22 does not 
call for a 300 baud fallback; the CCITT 
standard for 300 baud is V.21. It is not 
a required fallback for V.22, however, it 
is included in the VL7C212A. 
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V.22 also calls for guard tones to be 
sent along with the data. In most of 
Europe the tone is 1800 Hz except in 
Sweden where 550 Hz is used. The 
VL7C212A modem has the 550 Hz and 
1800 Hz tone generators built in as well 
as the 550 and 1800 Hz notch filter to 
remove the guard tone when in the 
receive mode. 


All modems require a hybrid. Hybrid is 
a term used to describe a circuit, 


TABLE 1. DEFINITION OF I/O CODES 


1. Instructions to the modem IC 


VL7C212A 


passive or active, that takes the 
separate transmit and receive signals 
and combines them to go over the 
phone line. ln'the VL7C212A, this is 
done with op amps, but the separate 
signals (TXOUT and RXA2) are also 
brought out so an external hybrid can 
be used, if desired. The combined 
signal comes out on the RXA1 pin and 
a matching resistor (typically 600 Q) is 
connected between RXA1 and RXA2. 


Data on the D I/O pin is shifted into the modem when WR is low, on rising edges of the SCK clock. Data is transferred 
into a latch when WR goes high. (See Figure 2 for write cycle waveforms.) Up to seven data bits (D0--D6) can be sent 
to the device. These bits control the operating modes of the modem as show below 


D6 
Mode/Function 


OQOOOQOOOOOOOOOQOOOOOQQOOO 
-B-I~—l-I-l—l—l—*—-5-*OOQQOC)OOOOOOC)CDCDCD 
coco\iowu1:>ooru-o'I1rrIUOtn><O<1>\lO><J1¢>(~>N-O 


Non-Tone Mode: 
Reset (set default values) 
Tone On/Off 
Force Receive Data to Mark Off/On 
TLCO 
Transmit Level Control Bit 0 (default 0) 
TLC1 
Transmit Level Control Bit1 (default 0) 
TX 
Transmitter On/Off 
ALB 
Analog Loopback On/Off 
CPM 
Call Progress Monitor Mode On/Off 
Connection Indicator (Cl) On/Off 
ALCO 
Audio Output Level Control Bit 0 (default 0) 
ALC1 
Audio Output Level Control Bit 1 (default 0) 
WLSO 
Word Length Select 0 (default 0) 
WLS1 
Word Length Select 1 (default 1) 
SynclAsync 
LS/HS: Low Speed/High Speed 
A/0: 
Answer/Originate 
Transmit Mark On/Off 
Transmit Space On/Off 
Scrambler Disable On/Off 
DLB 
Digital Loopback On/Off 
TXDP Transmit Dotting Pattern On/Off 
Locked/Internal 
External/Slave 
2100 Hz Tone On/Off (Must select low speed mode for operation) 
1300 Hz Tone On/Off (Must select low speed mode for operation) 
V.21 On/Off (Must select low speed mode for operation) 
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TABLE 1. DEFINITION OF I/O CODES (Cont.) 


‘>6 31% 


—L—L—L-A—L—L—L-L-L—L—L_L—L—L1L-L 


1/O 
1/O 
1/O 
1/O 
1/O 
1/O 
1/O 
1/0 
1/O 
1/0 
1/O 
1/O 
1/0 
1/0 
1/O 
1/O 


WLS1 


---oo 
_;Q_;Q 


TLC1 


_L_L°o 
-.A@-.A@ 


ALC1 


--~oo 


2. Information from the Modem IC 


-Lo-Lo 


oooooooooooooooo 
-nmU()m>coco\ro>014>ooro-0 


WLSO 


_;Q..;Q 


-Lo-Lo 
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Tone Mode: 
Dial 0 
Dial 1 
Dial 2 
Dial 3 
Dial 4 
Dial 5 
Dial 6 
Dial 7 
Dial 8 
Dial 9 
Dial * 
Dial # 
Output 550 Hz and Insert 550 Hz Notch in Low-Band Filter 
Output 1800 Hz and Insert 1800 Hz Notch inLow-Band Filter 
Row Disable On/Off 
Column Disable On/Off 


Word Length 


8 Bits 
9 Bits 
10 Bits (default) 


Mode/Function 


11 Bits 


Transmitter Output Level (dBm) at the Phone Line 


-12 (default) 
-9 
-s 
o 


Audio Output Level 


Output Off (default) 
12 dB Attenuation 
6 dB Attenuation 
No Attenuation 


VL7C212A 


Data is read serially from the modem when RD is low, on rising edges of the SCK clock. (See Figure 1 for read cycle 
waveforms.) Up to four data bits (D0--D3) can be read as defined below: 


DO 
Energy Detect 
0 - No Energy 
1 - Energy Present 


In the CPM mode, the energy detector is connected to the output of the high-band filter, if ALB is off, or the scaled Iow- 
band filter, if ALB is on. 


D1 
D2 
D3 


Notes 


Received Data (FSK) 
1 - Mark 
0 - Space 
Received Data (PSK) 
1 - Mark 
0 - Space 
Unscrambled Mark 
1 - Detected 
0 - Not Detected 


1. Default values for the operating modes on power-up are those shown to the right of the "I" unless otherwise specified. 
2. Data is shifted in and out of the modem with LSB first. 
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TABLE 2. AC CHARACTERISTICS 


tDW 
E--E 
‘DR 
m——n 
‘PW 
“E 
‘P 
E! 
‘° 
T 


FIGURE 1. WAVEFORMS FOR WRITE AND READ CYCLES 
a) Wrlte qcle 


—Ol 
IDW 
I0-— IDW 


Condltlons 


Duty Cycle 


--WR 


"W IOXNHEENEHIIOI 


I 
I 


ii=w_.| 
|._ 
_.||._ir> 
b) Read Cycle 
—0| 
tDR 
-0‘ 
tDR 


-RD 


° W IOIQNHEEDIOIOIOIOI 


DTMF GENERATOR CRYSTAL FREQUENCY = 1.3"/zaoo MHz ¢o% 
Parameter 
Nominal Frequency 
Allowable Error 


Row 1 
697 Hz 
i 1°/ 


Row 2 
770 Hz 
:l:1°/ 


Row 3 
i 1°/ 


Row 4 
941 HZ 
i1°/ 


Column 1 
i 1°/ 


Column2 
1336 Hz 
It 1°/ 


Column 3 
1477 Hz 
i1‘7 


zt 20 Hz 
Guard Tones 
1800 Hz 
:i= 20 Hz 
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VL7C21 2A 



Actual Error 


+ 0.17% 


— 0.26% 


f 
. 
» 
+ 0.16% 


- 0.47% 


- 0.74% 


-0.89% 


- 0.01% 


— 1.4 Hz 


+7Hz 
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DTMF GENERATOR (Cont.) 


Second Harmonic Distortion 
VCC = + 5 V 
dB 


Row Output Level 
VSS = — 5 V 
dBm 


Column Output Level 
TLCO = 1 
dBm 


550 Hz Guard Tone Level 
TLC1 = 1 
dB (Note 2) 


1800 Hz Guard Tone Level 
Measured at TXOUT Pin 
dB (Note 2) 


Note: Guard tone levels are referenced to the TX signal level. When guard tones are added, the TXOUT level is adjusted to 
maintain a constant level on the line. For 1800 Hz, the adjustment is -0.97 dB; for 550 Hz, the adjustment is -1.76 dB, per the 
CCITT specification. 


MODEM TRANSMIT SIGNALS CRYSTAL FREQUENCY = 1.312800 MHz 20% 


Bell 103 
com v 21 
Bell 212A / CCITT v.22 
Mode 


Mark 
1649 4 Hz 
Answer 
Space 
2024 4 Hz 
18506 Hz 


Mark 
1270 HZ 
1269 4 HZ 
980 HZ 
978 34 HZ 
Originate 
Space 
1070 Hz 
1070.4 Hz 
1130 Hz 


Calling Tone 


Actual 


2400 Hz 


1200 Hz 


1301 7 Hz 
1301.7 Hz 


Answer Tone 
20959 Hz 
2100 Hz 
2096.9 Hz 


RECEIVER 


Parameter 


Input Signal Range 


Intra - Character Bit Rate 


Carrier Detect 


Carrier Detect Hysterisis 


Carrier Detect Delay 


Carrier Detect Hold 


Carrier Detect Delay 


Carrier Detect Hold 


Condltlons 
T 


#-5 


‘O 


N 


At RXA1 ( pin 9 ) 
._ 


AtRXD(r>in13) 
1170 
1224 


At RXA1 (pin 9) 
_ 


For 103 212A and V 22 


For 103 212A and V 22 


For V 21 mode 


For V 21 mode 
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Units 


dBm 


bps 


dBm 


dB 


ms 


ms 


ms 


ms 
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TRANSMITTER 
Parameter 
Condltlons 
T 
Units 


-L 
‘O 
e-Q1Wat 


Input Character Length 
gran Bit + Data Bit + stop git 
11 
bits 


Intra - Character Bit Rate 
At TXD (pm 14) 
1170 
1212 
bps 


Input Break Sequence Length 
M = Qharactgr Length 
2M + 3 


Output Level Tolerance 


ABSOLUTE MAXIMUM RATINGS 


Ambient Temperature 
Stresses above those listed under 
those in the operational sections of this 
Under Bias: 
-10°C to +80°C 
“Absolute Maximum Ratings" may 
specification is not implied and expo- 
Storage Temperature 
cause permanent damage to the 
sure to absoute maximum rating 
Range, 
_65,,C to +1 40°C 
device. These are stress ratings only. 
conditions for extended periods may 
' 
Functional Operation of this device at 
effect device reliability. 
MHXIWIUHI Supply 
these or any other conditions above 
Voltage: 
VCC = +7.0 V, VSS = -7.0 V 


Input Voltage Range: 
Analog Pins; VSS -0.6 V to VCC+0.6 V 
Digital Pins; DGND—0.6 V to VCC+0.6 V 


Maximum Power 
Dissipation @25°C: 
500 mW 


DC CHARACTERISTICS TA= 0°C to 70° C unless otherwise specified 


Symbol 
Parameter 
T 
Conditions 


SSS§ 
'_I 


"0 
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VCC 
Positive Supply Voltage 


VSS 
Negative Supply Voltage 


ICC 
Quiescent Current 
VCC = 5 V 


ISS 
Quiescent Current 
VSS = -5 V 


High Level Input Voltage 
Digital Signal Pins: -RD» -WR» DI/Q» 


SCK,TXCK1,TXD 


Low Level Input Voltage 
Digital Signal Pins:-FID- -WR» DI/O» 


SCK, TXCK1, TXD 


VOH 
High Level Output Voltage 
@lOH= 40 i,iA 
(D 3 P5081 D I/0. CKQUT. 


@IQH-= 500 |,i.A 
RXD, TXCKO, RXCK) 


VOL 
Low Level Output Voltage 
@lOL=160 |.iA (D S Pins: D I/O, CKOUT, 


RXD, TXCKO, RXCK) 


VOM 
Maximum Output Signal 
Vp p 
TXQUT, Ft|_..12o0 Q (TLC1-1, Tl_c0..o) 


VOM 
Maximum Output Signal 
Vp p 
Audio Out, RL-= 50 kn 


Maximum Input Signal 
Vp p 
RXA1, RXA2 
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FEATURES 
- 
Direct interface to VL7C212A single- 
chip modems 


- Complete Hayes AT command set in 
firmware 


- Built-in UART 


- Direct IBM PC bus interface 


- Two-micron CMOS process 


- 28-pin DIP or PLCC package 


- Complete intelligent modem in two ICs 


- Compatible with industry-standard 
software 


- Replacement for Sierra SC11007 


- Reduces board space and component 
count requirements 


PARALLEL BUS MODEM CONTROLLER 


DESCRIPTION 
The VL7C213 Parallel Bus Modem 
Controller is specifically designed to 
control the VL7C212A single-chip, 300/ 
1200 bit-per-second modem. Built with 
an advanced two-micron CMOS 
process, the VL7C213 provides a 
highly cost effective solution for 
interfacing a modem IC to a system 
bus. When connected to the 
VL7C212A, with the addition of a data 
access arrangement (DAA), the 
VL7C213 implements a Hayes-type 
smart modem for board-level, integral-' 
modem applications. Because the 
VL7C213 fully emulates the functional- 
ity of the VL82C50 UART and includes 
data bus transceivers, it can be directly 
interfaced to a computer's parallel data 


bus (in particular to the bus of the IBM 
PC, XT or AT). All of the popular com- 
munications software written for the PC 
will work with the VL7C213/ 
VL7C212A chip set. In addition to 
including the functionality of the 
VL82C50 UART, the VL7C213 contains 
an 8-bit microprocessor, 8K by 8 bits of 
ROM and 128 by 8 bits of RAM. 


For specific high-volume applications, 
the control program can be modified by 
VLSI to include additional command 
functions. 


PIN DIAGRAMS 
BLOCK 
DIAGRAM 


-cost -A 


-cs -_->-—-» 
——-» 
-- 
00-07 
INTERFACE 


‘NT i 


-oosr 
-DIST 
TEST 
KDV 
-RI 
oH 
cu< 
-we 
-no 
SCK 
Di/O 
TXD 
RXD 
GND 


XU 


—Rl5 
OH6 


12s4567a9 
10 
11 
12 
1a 
14 


TEST 
-DO 


V 
—DlST 


VL7C213 


28 VCC 
27 


61811‘?-?68'2-’I8B§2ii3Z 
IIIIIIIIIIII 
ssssaaasgazaa 


(D 


-I 
<->I NI 
0-I 
8.§'3I 31.3 
25 
24 


CLK I 
1 
2° 
TOP VIEW 
22 
-WR8 
-no 
9 
2' 
SCK10 
2° 
DVO11 


RXD 
DO 


19 


Slat 
0.6 
glii 
I5 
9.8 
Iii 
8.8 


D2 


UART MONITOR 
UART CONTROL 
REGISTER 
REGISTER 


ST "cs 
OMBL 
' 
/SUBRUTI 
REGISTER 
STACK 


ROM 
8KX 8 
‘\J 


INSTRUCTION 
REGISTER 


a 


ACCUMULATOR 
TIMER 
CONTROL PLA 


ORDER 
INFORMATION 


Part 
Number 
Package 
VL7C213-PC 
Plastic DIP 
VL7C213-QC 
Plastic Leaded Chip Carrier (PLCC) 
Note: Operating temperature range is 0°C to +70°C. 


RAM 
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PORT 1 
3% 
-WR 
DI/O 


KDV 
OH 
—Rl 
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SIGNAL 
DESCRIPTIONS 


Slgnal 
Pln 
Signal 
Name 
Number 
Descrlptlon 


-DOST 


--DIST 


TEST 


KDV 


-RI 


on 


CLK 


-WR 


-RD 


SCK 


DI/0 


The CPU can write data or control words into a selected register of the VL7C213 when 
-DOST is low and the chip is selected. Data is latched on the rising edge of the signal. 


The CPU can read data or status information from a selected register of the VL7C213 
when --DIST is low and the chip is selected. 


When the test input is high, the VL7C213 enters a test mode (used for factory testing 
only). No connection must be made to this pin. It must be left open for normal operation. 


This output controls the operation of the data/voice relay. When low, the data/voice relay 
is off and the phone line is connected to the phone set. During a data call, the VL7C213 
makes this output high to operate the data/voice relay, disconnecting the phone set from 
the phone line. It may also be used to drive a relay for multi-line phone applications to 
close the A and A1 leads. 


The output of the ring detector in the DAA is connected to this input. A low level on this 
input indicates the "On" duration of the ring cycle. This is a Schmitt-trigger input, 
allowing for slow rising and falling signals on this pin. 


This output controls the operation of the hookswitch relay in the DAA. During a data call, 
this output is high. It operates the hookswitch relay which causes the phone line to be 
seized. During rotary dialing, the VL7C213 pulses this output at a rate of 10 pulses per 
second with appropriate Mark/Space ratio depending on 212A or V.22 mode. 


A 7.3728 MHz clock signal must be connected to this input. Normally, the CKOUT pin of 
the VL7C212A modem is connected to this pin. All internal timing is derived from this 
clock. This clock must be adjusted to within 0.01%. 


This pin is used to initiate writing of data to the VL7C212A modem. On power-up, it is an 
input for a brief time in which the VL7C213 reads the carrier status switch connected to 
this pin. If the switch is closed to ground through an 18 Kn resistor, the VL7C213 sets 
the Received Line Signal Detect (RLSD) Bit in the Modem Status Register. If the switch 
is open, the VL7C213 resets this bit and writes the actual status of the carrier detector 
during a data call. If no switch is used, an internal pull-up sets the status during power- 
up to the default state (pull-up to VCC) which is to follow the remote modem's carrier. 


This pin is used to initiate reading of data from the VL7C212A modem. On power-up, 
this pin is an input for a brief time in which the VL7C213 reads the DTR status switch 
connected to this pin. If this switch is open, the VL7C213 reacts to the status of the DTR 
bit in the UART Modem Control Register. If the switch is closed to ground through 18 
kn, the VL7C213 ignores the state of the DTR bit. When the switch is open, writing a 
zero to the DTR bit in the Modem Control Registerforces the VL7C213 into the com- 
mand state and when on-line, causes it to hang up. If no switch is used, an internal pull- 
up to VCC sets the status during P0wer-up to the default state (to follow the DTR status). 


The VL7C213 supplies a shift clock on this pin to the VL7C212A modem for reading or 
writing data. On power-up, this pin is an input for a brief time in which the VL7C213 
reads the Bell/CCITT select switch connected to this pin. If this switch is open, Bell 
protocol is selected. If this switch is closed to ground through18 kn, CCITT V.22 
protocol is selected. If no switch is used, an internal pull-up sets the status during 
power-up to the default state (212A mode). 


The VL7C213 shifts data serially out of this pin to VL7C212A during a write operation 
and shifts data serially into this pin during a read operation from the VL7C212A. On 
power-up this pin is an input for a brief time in which the VL7C213 reads the Make/Break 
ratio select switch connected to this pin for selecting the pulse dialing standard. With the 
switch open, the Bell standard 39% Make, 61% Break is selected. With the switch 
closed to ground through 18 kn, the CCITT standard 33% Make, 67% Break is selected. 
If no switch is used, an internal pull-up sets the status during power-up to the default 
state (Bell standard). 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
Pln 
Number 
Name 


TXD 


RXD 


GND 


D0-D7 


INT 


A0-A2 


—CS 


VCC 


12 


13 


14 


15-22 


23 


24-26 


27 


28 


Slgnal 
Descrlptlon 
This pin is a serial output pin. During a data call, alter the connection is established, the 
VL7C213 converts parallel data received from the computer bus and outputs it in a 
serial, asynchronous format to the VL7C212A modem for modulation. At all other times 
the VL7C213 holds this output in the Mark (high) condition. 


Demodulated data from the VL7C212A modem is received on this pin during a data call. 
A high level is considered Mark and a low level is Space. The VL7C213 converts the 
serial data into a parallel data byte and stores it in the Receiver Buffer Register (RBR). 
The Data Ready bit in the Line Status Register (LSR) is then set, and an appropriate 
interrupt identification code is written in the Interrupt Identification Register (IIR) to signal 
to the computer, the reception of a new data byte. 


Ground reference (0 V). 


This is the 8 bit data bus comprising of three-state input/output lines. This bus provides 
bidirectional communication between the VL7C213 and the CPU. Data control words 
and status information are transferred via the D0 - D7 data bus. 


This output goes high whenever any one of the following interrupt types has an active 
condition and is enabled via the IER: Receiver Line Status flag, Received Data Avail- 
able, Transmitter Holding Register Empty, and Modem Status. It is reset low upon the 
appropriate interrupt servicing. The INT pin is forced to a high impedence state when 
the OUT2 bit of the Modem Control Regiser (MCR) is low (power on state). 


These three address inputs are used during read or write operation to select a UART 
register in the VL7C213 as shown in Table 1. The Divisor Latch Access Bit (DLAB) must 
be set high by the system software to access the bit rate divisor latches as shown in 
Table 2. 


The VL7C213 is selected when this input is low. When high, the VL7C213 forces the 
Data bus lines into a high impedance state. 


Positive supply (+5 V). 


TABLE 1. VL7C213 UART REGISTERS 
"LAB HNNM 
"W" 
4 


O 
O 
O 
O 


0 


0 


X 


X 


X 


X 


X 


X 


1 
O 


1 
O 


O 


0 


O 


O 


O 


RBR 


THR 


IER 


IIR 


LCR 


MCR 


LSR 


MSR 


STR 


DLL 


DLM 


Receiver Buffer Register (read only) 


Transmitter Holding Register (write only) 


Interrupt Enable Register 


Interrupt Identification Register (read only) 


Line Control Register 


Modem Control Register 


Line Status Register 


Modem Status (read only) Register 


Speed 


Divisor Latch (LSB) (write only) 


Divisor Latch (MSB) (write only) 


X - "Don't Care” 
0 - Logic Low 
1 - Logic High 
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FIGURE 1 . UART BLOCK DIAGRAM 


INTERNAL 
DATA BUS 


DATA BUS 
RECEIVER 
no-07 
BUFFER 
BUFFER 
REGISTER 


LINE 
CONTROL 
REGISTER 


DIVISOR 
LATCH (LS) 
BAUD 
DMSOR 
GENERATOR 


LATCH (MS) 


A0 
LINE 
A‘ 
STATUS 
REGISTER[I 
A2 
SELECT 
AND 
—CS 
CONTROL 
I-QGIC 
SPEED 
REGISTER 
-DIST 


-DOST 


TRANSMITTER 
HOLDING 
REGISTER 


MODEM 
CONTROL 
REGISTER 


MODEM 
STATUS 
REGISTER 


INTERRUPT 
INTERRUPT 
ENABLE 
CONTROL 
REGISTER 
LOGIC 


INTERRUPT 
ID 
REGISTER 
. 
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RECEIVER 
SHIFT’ 
REGISTER 


RECEIVER 
TIMING AND 
CONTROL 


TRANSMITTER 
TIMING AND 
CONTROL 


TRANSMITTER 
SHIFT 
REGISTER 


MODEM 
CONTROL 
LOGIC 


RXD 


TXD 


INT 
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TABLE 2. VL7C213 UART REGISTER FUNCTION SUMMARY 


Reglster 
Register Bit Number 
M"°"‘°"'° 
Bit 0 
Bit 
B 1 2 
e t3 


RBR 


THR 


IER 


IIR 


LCR 


MCR 


LSR 


MSR 


DLM 


DLL 


STR 


Bit 7 
e 14 
e 1 5 
Bit 6 
EEE 
“as 
iii 
‘Ma 


Receive 
THRE 
Receive 
Modem 
0 
Data 
Interrupt 
Line 
Status 
Available 
Enable 
Status 
Interrupt 
Interrupt 
Interrupt 
Enable 
Enable 


0 if 
0 


Enable 


Interrupt 
Interrupt 
ID Bit 0 
ID Bit 1 


0 = 1 Stop 
1 = Parity 
1 = Even 
1 = Stick 
1 =- Set 
DLAB 


_ 
Bit 
Enable 
Parity 
Parity 
Break 
1 =- 8 Bit 
1 = 2 Stop 
Data 
Bits 


Request 
OUT1 
OUT2 
No 
0 
to Send 
0 = INT 
Function 
Output 
to HI-Z 


Data 
Overrun 
Parity 
Framing 
Break 
THRE 
TSRE 
0 
Ready 
Error 
Error 
Error 
Interrupt 


Trailing 
Delta 
1 rcrs) 
1 rose) 
RING 
RLSD 
I 
Edge Ring 
RLSD 
Ki 
“as 
i 
Dam 
Data 


Interrupt 
Pending 


0 = 7 Bit 
Data 


Data 
Terminal 
Ready 
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TABLE 3. VL7C213 SOFTWARE REGISTERS 


Register 


S0 


S1 


S2 


S3 


S4 


S5 


S6 


S7 


S8 


S9 


S10 


S11 


S12 


S13 


S14 


S15 


S16 


Range/Units 
Descrlptlon 


Ring to answer telephone on 


Number of rings 


0 127 ASCII 
Escape code character 


0 127 ASCII 
Character recognized as carriage return 


0 127 ASCII 
Character recognized as line feedback 


0 32 127 ASCII 
Character recognized as back space 


Wait time for dial tone 


Wait time for carrier 


Pause time (caused by comma) 


1 255 1/10 sec 
Carrier detect response time 


1 255 1/10 sec 
Delay between loss of carrier and hang up 


50 255 millisec 
Duration and spacing of Touch Tones 


20 255 1/50 sec 
Escape code guard time 


bit mapped 
UART status register 


bit mapped 
Option register 


bit mapped 
Flag register 


.0 
... 


I 


N Q 
. 
1 
Test modes 
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Default 


0 


0 


43 (+) 


13 (CR) 


10 (LF) 


8 (BS) 


2 


30 


2 


6 


7 


70 


50 


O 
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TABLE 4 COMMAND SUMMARY 


PREFIX REPEAT AND ESCAPE COMMANDS 


Command 
Descrlptlon (Notes 1 8 2) 


AT 


Al 


Attention prefix precedes all command lines except + + + (escape) and A/(repeat) commands 


Repeat last command line (Al IS not followed by carriage return) 


+ + + 
Escape code 
go from on line state to command state (one second pause before and after escape 
code entry, , + + + is not followed by carriage return) 


DIALING COMMANDS 


Command 
Descrlptlon (Notes 1 8 2) 
Descrlptlon (Notes 1 8 2) 


D 


P 


T 
— war for 1/8 --and 
l wa-:10:--I-4» 
_ 
Wait for second dial tone 
C 
Return to command state after dialing 
C 
Reverse mode (to call originate only modem) 


OTHER COMMANDS 


Commands 
Descrlptlon (Notes 1 8 2) 
Descrlptlon (Notes 1 8 2) 


A 
Answer call without waiting for ring 


B/B0 


B1 


C/C0 


C1 


E/E0 


E1 


F/F0 


F1 


H/H0 


H1 


H2 


V10 


I1 


I2 


L/L1 


L2 


Speaker on until carrier detected 


l'l'l' V 22 


03 and 212A 


(Note 3) 
Speaker always on 


Go to on line state 


it carrier off 
Transm 
Remote digital loopback off‘ 


Carner on‘ 
Remote digital loopback request 


Characters not echoed 
Result codes displayed 


Characters echo 
Result codes not displayed 


Half duplex 
Requests current value of register r 


Sets register r to value of n 


hook(hang up) 
Digit result codes 


hook, line and auxiliary relay 
Word result codes’ 


hook, line relay 
Compatible with Hayes type 300 modems 


Result code CONNECT 1200 enabled 


Firmware revision number 
— 
Enables dial tone detection 
— 
Enables busy signal detection 
— 
Enables dial tone and busy signal detection 


Long space csconnect disabled 
— 
Long space disconnect enabled 


est product ID code 


L3 


M/M0 
Speaker always off 
H 
Software reset restores all default settings 
Notes 
1. Default modes are indicated by 
2. Commands entered with null parameters assume 0 
X is the same as X0 
3. When the ATB command IS used in the answer mode, the VL7C212A is placed in either the V 21 or the V 22 mode, depend 
ing on the response from the remote modem 
In the originate mode, the VL7C213 will sense if the baud rate is set at 300 or 
1200 bits 
er second and will ad ust the VL7C212A accordin I 
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TABLE 
5 
RESULT 
CODES 


Digit Code 
Word Code 
Descrlptlon 


Command executed 


Connected at 300 or 1200 bps 


Ringing signal detected (Note) 


No Carrier 
Carrier signal not detected or lost 


Connect 1200 


No Dialtone 


No Answer 


Illegal command 
Error in command line 


VL7C213 


Connected at 300 bps, if result of X1, X2 X3, or X4 command 


Command line exceeds buffer (40 characters, including punctuation) 
Invalid character format at 1200 bps 


Results from X2 or X4 commands only 


Busy 
Busy signal detected and subsequent commands not processed 
Results from X3 or X4 commands only 


Results from @ command only 


Note 
When the VL7C213 detects a ringing on the telephone line, it sends a RING result code 
However, the VL7C213 
will answer the call only if it is in auto-answer mode or is given an A command. 


Register/Signal 


Receiver Buffer Register 


Transmitter Holding Register 


Interrupt Enable Register 


Interrupt Identification Register 


Line Control Register 


MODEM Control Register 


Line Status Register 


Modem Status Register 


Divisor Latch (high order bits) 


TABLE 6 
RESET CONTROL OF REGISTERS AND PINOUT SIGNALS 


Reset Control 


irst word received 


Writing into the Transmitter Holding Register 


ower on reset 


Power on reset 


Writing into the LCR 


Power on reset 


Power on reset 


Power on reset 


Power on reset 


Master reset 


Power on reset 
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Connected at 1200 bps. Results from X1 X2 X3, or X4 commands only 


Dialtone not detected and subsequent cxammands not processed 


Silence not detected and subsequent commands not processed 


Reset State 


All bits low 


Bit 0 high 
bits 1-7 low 


All bits low 


Bits 0-4 7 low 
bits 5-6 high 


Bits 0-3 6-7 low, 
bits 4-5 high 


1200 bps 


Low (high impedence) 
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UART 
REGISTERS 
Line Control 
Registers 
This register controls the format oi the 
asynchronous data communications. 


Bit 0 and 1: Bit 1 is always high. Bit 0 
specifies the number of bits in each 
transmitted or received serial character. 
The encoding of bit 0 is as follows: 


Bit 1 
Bit 0 
Word Length 


1 
0 
7 Bits 


1 
1 
8 Bits 


Bit 2: This bit specifies the number of 
Stop bits in each transmitted or re- 
ceived serial character. If bit 2 is a logic 
0, one Stop bit is generated or checked 
in the transmit or receive data, respec- 
tively. If bit 2 is a logic 1, when 7-bit 
word length with no Parity is selected, 
two Stop bits are generated or checked. 


Bit 3: This bit is the Parity Enable bit. 
When bit 0 is a logic 0 and bit 3 is a 
logic 1, a Parity bit is generated 
(transmit data) or checked (receive 
data) between the last data word bit and 
the Stop bit of the serial data. (The 
Parity bit is used to produce an even or 
odd number of 1s when the data word 
bits and the Parity bit are summed.) 


Bit 4: This bit is the Even Parity Select 
bit. When bit 3 is a Iogic1 and bit 4 is 
logic 0, and odd number of logic 1s is 
transmitted or checked in the data word 
bits and Parity bit. When bit 3 is logic 1 
and bit 4 is a logic 1, an even number of 
bits is transmitted or checked. 


Bit 5: This bit is the Stick Parity bit. 
When bit 3 is logic 1 and bit 5 is logic 1, 
the Parity bit is transmitted and then 
detected by the receiver in the opposite 
state indicated by bit 4. 


Bit 6: This bit is the Set Break Control 
bit. When bit 6 is a logic 1, the serial 
output (TXD) is forced to the Spacing 
state (logic 0) and remains there (until 
reset by a low-level bit 6) regardless of 
other transmitter activity. The feature 
enables the CPU to alert a terminal in a 
computer communications system. 


Bit 7: This bit is the Divisor Latch 
Access Bit (DLAB). It must be set high 
(logic 1) to access the Divisor Latches 
of the Baud Rate Generator during a 
Read or Write operation. It must be set 
low (logic 0) to access the Receiver 
Buffer, the Transmitter Holding Regis- 
ter, or the interrupt Enable Register. 


Programmable Baud Rate Generator 
The VL7C213's Baud Rate Generator 
can be programmed for one of six baud 
rates. The desired speed is selected by 
writing into the Divisor Latch (DLM) . 
On reset, the rate will be 1200 baud. 


DLM (Hex Code) 
Baud Rate 
00 
1200 
01 
300 
03 
150 
04 
110 
06 
75 
09 
50 


Line Status Register 
This 8-bit register provides status 
information to the CPU concerning the 
data transfer. The contents of the Line 
Status Register are indicated in Table 2 
and are described below: 


Bit 0: This bit is the receiver Data 
Ready (DR) indicator. Bit 0 is set to a 
logic 1 whenever a complete incoming 
character has been received and 
transferred into the Receiver Buffer 
Register. Bit 0 will reset to a logic 0 
either by the CPU reading the data in 
the Receiver Buffer Register or by 
writing a logic 0 into it from the CPU. 


Bit 1: This bit is the Overrun Error (OE) 
indicator. Bit1 indicates that data in the 
Receiver Buffer Register was not read 
by the CPU before the next character 
was transferred into the Receiver Buffer 
Register, thereby destroying the 
previous character. The OE indicator is 
reset whenever the CPU reads the 
contents of the Line Status Register. 


Bit 2: This bit is the Parity Error (PE) 
indicator. Bit 2 indicates that the 
received data character does not have 
the correct even or odd parity, as 
selected by the even parity select bit. 
The PE bit is set to a logic 1 upon 
detection of parity error and is reset to a 
logic 0 whenever the CPU reads the 
contents of the Line Status Register. 


Bit 3: This bit is the Framing Error (FE) 
indicator. Bit 3 indicates that the 
received character did not have a valid 
Stop bit. Bit 3 is set to a logic 1 
whenever the Stop bit following the last 
data bit or parity bit is detected as a 
zero (Spacing level). 


Bit 4: This bit is the Break Interrupt (Bl) 
indicator. Bit 4 is set to a logic 1 


whenever the received data input is 
held in the Spacing (Logic 0) state for 
longer than a full word transmission 
time - the total time of Start bit + data 
bits + Parity + Stop bits. 


Bit 5: This bit is the Transmitter Holding 
Register Empty (THRE) indicator. Bit 5 
indicates that the VL7C213 is ready to 
accept a new character for transmis- 
sion. In addition, this bit causes the 
VL7C213 to issue an interrupt to the 
CPU when the Transmit Holding 
Register Empty enable is set high. The 
THRE bit is set to a logic 0 concurrently 
with the loading of the Transmitter 
Holding Register by the CPU. 


Bit 6: This bit is the Transmitter Shift 
Register Empty (TSRE) indicator. Bit 6 
is set to a logic 1 whenever the Trans- 
mitter Shift Register is idle. it is reset to 
logic 0 upon a data transfer from the 
Transmitter Holding Register to the 
Transmitter Shift Register. 


Bit 7: This bit is permanently set to 
logic 0. 


Bitv: 1 through 4 are the error conditions 
that produce a Receiver Line Status 
interrupt whenever any of the corre- 
sponding conditions are detected. 


Interrupt identification Register 
The VL7C213 has an on-chip interrupt 
capability that allows for complete 
flexibility in interfacing to all popular 
microprocessors. To provide minimum 
software overhead during data charac- 
ter transfers, the VL7C213 prioritizes 
interrupts into four levels. The four 
levels of interrupt conditions are as 
follows: Receiver Line Status (priority 
1); Received Data Ready (priority 2); 
Transmitter Holding Register Empty 
(priority 3); and MODEM Status (priority 
4). 


Information indicating that a prioritized 
interrupt is pending the source of that 
interrupt are stored in the interrupt 
Identification Register (refer to Table 7). 
The Interrupt Identification Register 
(IIR), when addressed during chip- 
select time, freezes the highest priority 
interrupt pending and no other inter- 
rupts are acknowledged until the 
particular interrupt is serviced by the 
CPU. The contents of the IIR are 
indicated in Table 2 and are described 
below. 
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Bit 0: This bit can be used in either a 
hardwired prioritized or polled environ- 
ment to indicate whether an interrupt is 
pending. When bit 0 is logic 0, an 
interrupt is pending and the IIR contents 
may be used as a pointerto the 
appropriate interrupt service routine. 
When bit 0 is a logic, no interrupt is 
pending. 


Bits 1 and 2: These two bits of the IIR 
are used to identify the highest priority 
interrupt pending as indicated in Table 
7. 


Bits 3 through 7: These five bits of the 
IIR are always logic 0. 


lnterruptEnabie Register 
This 8-bit register enables the four 
interrupt sources of the VL7C213 to 
separately activate the Interrupt (INT) 
output signal. it is possible to totally 
disable the interrupt system by resetting 
bits 0 through 3 of the Interrupt Enable 
Register. Similarly, by setting the 
appropriate bits of this register and the 
active (high) INT output from the chip. 
All other system functions operate in 
their normal manner, including the 
setting of the Line Status and MODEM 
Status Register. The contents of the 
interrupt Enable Register are indicated 
in Table 2 and are described below. 


Bit 0: This bit enables the Received 
Data Available Interrupt when set to 
logic 1. 


Bit 1: This bit enables the transmitter 
Holding Register Empty interrupt when 
set to a logic 1. 


Bit 2: This bit enables the Receiver 
Line Status Interrupt when set to logic 
1. 


Bit 3: This bit enables the MODEM 
Status Interrupt when set to logic 1. 


Bit 4 through 7: These four bits are 
always logic 0. 


MODEM Control Register 
This 8-bit register controls the interface 
with the MODEM. The contents of the 
MODEM Control Register are indicated 
in Table 2 and are described below. 


Bit 0: This bit controls Data Terminal 
Ready (DTR) signal. If the external 
switch on the -RD pin is set to VCC 
through an 18 kn resistor, setting the 
DTR low will force the VL7C213 into the 
command state and if on line, it will 
hang up. 


Bit 1: This bit controls the Request to 
Send (RTS) signal. This signal is not 
used by the VL7C213. 


Bit 2: This bit controls the Output 1 
(OUT1) signal. This signal is not used 
by the VL7C213. 


Bit 3: This bit controls the Output 2 
(OUT2) signal. When OUT2 is a 0, the 
interrupt output is in high impedence 
state. 


Bit 4: Not used. 


Bits 5 through 7: These bits are 
permanently set to logic 0. 


MODEM Status Register 
This 8-bit register provides the current 
state of the control lines from the 


MODEM (or peripheral device) to the 
CPU. in addition to this current-state 
information, two bits of the MODEM 
Status Register provide change 
information. These bits are set to a 
logic 1 whenever a control input from 
the MODEM changes state. They are 
reset to logic 0 whenever the CPU 
reads the MODEM Status Register. 


The contents of the MODEM Status 
Register are indicated in Table 2 and 
are described below. 


Bits 0 and 1: These bits are always 0. 


Bit 2: This bit is the Trailing Edge of 
Ring Indicator (TERI) detector. Bit 2 
indicates that the -RI input to the chip 
has changed from On (logic 1) to an Off 
(logic 0) condition. 


Bit 3: This bit is the Delta Received 
Line Signal Detector (DRLSD) indicator. 
Bit 3 indicates that the carrier detector 
has changed state. 


Bit 4: This bit is always 1. 


Bit 5: This bit is always 1. 


Bit 6: This bit is the complement of the 
Ring Indicator (-RI) input. 


Bit 7: This bit is the Received Line 
Signal Detect (RLSD) signal. 


Whenever bit 2 is set to logic 1, or bit 3 
changes state, a MODEM Status 
interrupt is generated if enabled. 
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TABLE 
7. 
INTER 


Interrupt 
ldencaon 
Register 


RUPT 
CONTROL 
FUNCTIONS 


Interrupt Set and Reset Functions 


B“ 2 
Priority 
Interrupt 
Level 
Interrupt Flag 
Interrupt Source 
Reset control 


OC) 
-* 
—*O 


Highest 
Receiver 
Overrun Error or 
Reading the Line 
Line Status 
Parity Error or 
Status Register 
Framing Error or 
Break interrupt 


Second 
Received Data 
Received Data 
Reading the Receiver 
Available 
Available 
Buffer Register 


Third 
Transmitter Holding 
Transmitter Holding 
Reading the IIR (II source of 
Register Empty 
Register Empty 
interrupt) or Writing into the 
Transmitter Holding Register 


Fourth 
Ring Indicator or 
Reading the MODEM 
Received Line 
Status Register 
Signal Detect 
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FIGURE 2. ADDRESS DECODER CIRCUIT 


PC BUS 
NAME 


A1 1 


A28 


A27 


A26 


A25 


A24 


A22 


A23 


B24 


B25 


B14 


B13 


A29 


A30 


A31 


—AEN 


A3 


A4 


A5 


A6 


A7 


A9 


A8 


IRQ4 ¢ 


IRQ3 ———¥ 


—IOR 


-IOW 


A2 


A1 


A0 


74LS04 
>‘ 
11 
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8 
0 


74LS04 


----------— —DlST 
i---— -oosr 


VL7C213 


—CS 
27 
-CS 


VL7C213 


COM 2 


COM 1 


COM 1 


COM 2 


23 
INT 


2 
-DIST 


1 
-DOST 


25 
A2 


26 
A1 


24 
A0 
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AC CHARACTERISTICS 
TA = 0 TO 1o=>c, vcc = s v ¢1o% 


Symbol 
Parameter 


-DIST Strobe Width 


Read Cycle Delay 


Read Cycle 


tDDD 
Dela from -DIST to Data 


-DIST to Floating Data Delay 


-DOST Strobe 


e Cycle Delay 


e Cycle -= tDOW + tWC + 20 


Data Setup Time 


Data Hold Time 


tDlC 
-DIST Delay from Select 


-DOST Dela 


IRC + 20 


tDOW 
Width 


IDOC 
Select 


hip Select Hold 


IACW 
Ad 
hip Select Hold 
- 


—DIST 


DOST 


me fro 


me fro 
Receiver 


tRlNT 
Delay from -DIST (Read RBR) to Reset Interrupt 
100 pF Load 
iii 100 PF Load 
Delay from initial INTR Reset to Transmit Start 
Baud Cycle 


Delay from Initial Write to interrupt 
Baud Cycle 
j—I Baud Crei- 
:——— 10° PF Load 


Transmitter 


Delay from -DOST 
THR) to Reset Interrupt 


Delay from Stop to Next Start 


(THRE) 


) to Reset I 


Note 
A TTL load is 40 uA sourced and 
1 6 mA sinked current 


Delay from 
top to 


Delay from 
ST (Read I 
nterrupt (THRE 


VL7C213 


Conditions 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1'lTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 


1TTL Load 
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FIGURE 3. READ CYCLE TIMING 


—-—D| 
tACR 
—CS 
V 
Ao, A1, A2 
VALID 
I 
A 
|<i- ronc 
:0|w 
mo 


-D'$T 
ACTIVE 
Z 


VL7C21 3 


ACTIVE 


-DOST 
| 
ACTIVE 
no 


:000>| 
L mz 9} 


DATA 
VALID 
no-[>7 
DATA 


FIGURE 4. WRITE CYCLE TIMING 


-‘Pl 
tACW 
—CS 
V 
Ao, A1, A2 
VALID 
I 
A 
I4-— 1000 
mow 
two 


-DQST 
ACTIVE 
ACTIVE 


OR 


-DIST 
2 
ACTIVE 


|<- ms >L~ mu-0| 


DATA 
D0_D7 
VALID DATA 
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FIGURE 5. RECEIVER TIMING 


RXD (RECEIVER 
|NpU'|' DATA) 
START 
DATA 
START 


Z 


P 
SAMPLE CLK 


INTERRUPT 
/ 
IX 


IRINT I4-— 
—D|ST 
(READ REC DATA 
BUFFER) 


FIGURE 6. TRANSMITTER TIMING 


TXD 
SERIAL OUT 


START 
PARITY 
START 


\ 
TA 
‘ STQP 
\ 
5 


NR3 I4_ 
tSS I4-— 


ISTI 
INTERRUPT 
I 
I4- 
(THRE) 
\ 
/ 
\ 
/ 
\ 


-DOST 
(WR THR) 


-DIST 
(RD ma) 


I‘;i"iR’l 
I4— tHR 


IIRI4- 


345 


N VLSI TECHNOLOGY, INC. 
VL7C213 


ABSOLUTE 
MAXIMUM 
RATINGS 


Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. Expo- 
Temperature 
0°C to +70°C 
permanent damage to the device. 
sure to absolute maximum rating 
Storage Temperature 
_65¢C to +150<>C 
Thesefare st:}essdrati.ngs ctarttlly, functional 
cgngitigns for extebnldted periods may 
0 era ion o 
is 
evice a 
ese or an 
a e 
evice re ia ii 
. 
Supply V°IIa9e Io 
oTI1er conditions above those indicated’ 
Y 
Ground Potential 
+6 V 


Applied Input 
Voltage 
-0.6 V to VCC +0.6 V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = o to +10 <>c, vcc = s v¢1o% 


VCC 


ICC 


VIH 


VIL 


VT+ 


VT- 


VOH 


VOL 


IL 


FCLK 


—EE 


Positive Supply Voltage 
4.5 Hill @ VCC = 5 V 
perating Current 
m 


Hi h 
evel ln 
o a e 
All pins except -RI 
g 
L 
put V lt g 
Low Level Input Voltage 
E 


Positive Hysterisis Threshold 
— 


Negative Hysterisis Threshold 
- 
—- 


High Level Output Voltage 


All pins except —Rl 
-RI pin 


-—Rl pin 


Digital signal pins D0 to D7 
and INT @ IOH = -6 mA 


All other output or l/O pins 
@ 
== -2 ITIA 


Digital signal pins D0 to D7 
and INT @ IOL = 6 mA 
Low Level Output Voltage 
_ 
0 4 
V 
All other output or l/O pins 


° 
@ IOL = 2 mA 
—- 


Note : 
This applies to all pins except TEST, which has an internal pull-down -WR, -RD, SCK, DI/O and switch input pins 
which have internal pull-ups. 
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FIGURE 7. INTEGRAL SMART MODEM CONFIGURATION FOR PC BUS APPLICATIONS 


COMPUTER 
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D0-D7 
D0-D7 


Ao 
OH 
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A1 
KDV— =>- 
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— 
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A2 
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Q 
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-DIST 
_ Qw 
RXD 
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IRQ4 
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we 


ADDRESS 
DECODER 


Figure 2 


-DOST 
TXD 


-CS 
DI/O 


SCK 


INT 
CLK 


VL7C212A 
MODEM 


RXD 


TXD 


RXA1 


DI/O 
RXA2 5 


CK 
TXOUT 


SPEAKER 
EQIIII 


In0 


"WR 
AUDIO 
CLKOUT 
OUT 


XTAL1 
XTAL2 


7.3728 
MHz 


OPTIONAL 
SWITCHES 
Z 
1: 
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S 


FEATURES 


- Direct interface to VL7C212A single 
chip modems 


- Complete Hayes AT command set in 
firmware 


- Built-in UART for RS232C interface 


- Two-micron CMOS process 


- 28-pin DIP or PLCC package 


- Complete intelligent modem in two ICs 


- Compatible with industry-standard 
software 


- Reduces board space and component 
count requirements 


- Low power consumption 


- Replacement for Sierra SC11008 


PIN DIAGRAMS 
VL7C214 


KDV/—KDV 


—RI 


OH/-OI-I 


CLK 


-WR 


-RD 


SCK 


DI/O 


N.C. 
N.C. 
TEST 


-RI 
ow-ou 
cu< 
-we 
-no 
SCK 
DI/O 
TXD 
RXD 
GND 


12a45e7e9 
10 
11 
12 
1a 
14 


TEST 
KDV! 
-KDVI 
4s 
0 
7 
e 
9 
10 
. "12 13 
I I I I I I I 
TXD 
GND 
WORD 
ECHO EN 


28 
27 
26 
25 
24 
23 
22 
21 
20 
19 
18 
17 
16 
15 


VCC 
-DTR 
—CD 
-AA 
-HS 
N.C. 
MS SEL 
212A/-V.22 
-CMD EN 
-AA DIS 
ECHO EN 
-RES EN 
WORD 
-PS 


N.C. 
-DTR 


TU’ VIEW 


"I 
0-—I 
8-§QI BIIQ25-AA 
24 
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STAND-ALONE MODEM INTERFACE CONTROLLER 


DESCRIPTION 


The VL7C214 Stand-Alone Modem 
Interface Controller is specifically 
designed to control the VL7C212A 
single-chip, 300/1200 bit-per-second 
modem. Built with an advanced two- 
micron CMOS process, the VL7C214 
provides a highly cost effective 
solution for interfacing a modem IC to 
a computer’s RS232C port. When 
connected to the VL7C212A, with the 
addition of a data access arrangement 
(DAA), the VL7C214 implements a 
Hayes-type smart modem for stand- 
alone modem applications. All of the 
popular communications software 
written for the IBM PC will work with 
the VL7C214NL7C212A chip set. The 


BLOCK DIAGRAM 


VL7C214 contains an 8-bit microproces- 
sor, 8K by 8 bits of ROM and 128 by 8 
bits of RAM. In order to support the 
stand-alone functionality of the device, 
an 8-bit switch input port allows immedi- 
ate user access and manual control of 
the system. Either Bell 103 or CCITT 
V.22 may be selected in this manner. 


For specific high volume applications, 
the control program can be modified by 
VLSI Technology, Inc. to include 
additional commands and functions. 


UART 
éé 


"’€ 


UART 
BAUD 
INTERFACE 
REGISTERS 


W 


TRANS 
TXD 


OL 
RCVR 
RXD 


ROM BLOCK 
PC/SUBROUTINE 
REGISTER 


STACK 


OM 
8K X 8 


2 I 
MS SEL 


21 I 
212A/-V.22 


2° I '°"° E“ 
ACCUMULATOR 
T 
R 
coMTnoi.Pui 
.. . -AADIS 
i 
14 
15 
16 
17 
18 
\J' 


128 X 8 
8 
nxo 
-PS -RES EN 
PORT 1 
% 


ORDER INFORMATION 
W533 
BI/I5‘ 
-RES EN 
swn.cH 
Pa" 
55535.’; 
WPW 
Number 
Package 
-CMD EN 
PORT 
VL7C214-PC 
Plastic DIP 
=*=",y;",-gi 


PIHSIIC Leaded 
CHTIIST 
_Hs _AA ¢o_o~|-R 
KDV _a,.| _a| 
Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL 
DESCRIPTIONS 


Slgnal 
Pln 
Name 
Number 


N.C. 
1 


N.C. 
2 


TEST 
3 


KDV/—KDV 
4 


—RI 
5 


OH/—OH 
6 


CLK 
7 


-WR 
8 


-RD 
9 


SCK 
10 


DI/0 
11 


TXD 
12 


RXD 
13 


GND 


—PS 


14 


15 


WORD 
16 
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Slgnal 
Descrlptlon 


No connection 


No connection 


When the test input is high, the VL7C214 enters a test mode (used for factory testing 
only). For normal operation, this pin can be left open or connected to ground. 


This output controls the operation of the data/voice relay. The polarity of this output is 
selected by -PS pin. If -PS is connected to ground, this output is active high, i.e., it is 
low when modem is on hook, causing the data/voice relay to be off and the phone line is 
connected to the phone set. 
During a data call, this output goes high to operate the 
data/voice relay, disconnecting the phone set from the phone line. It may also be used 
to drive a relay for multi-line phone applications to close the A and A1 leads. If —PS pin 
is left open or connected to VCC, this output is active low, i.e., it is high when the modem 
is on hook and low when modem makes a data call. 


The output of the ring detector in the DAA is connected to this input. A low level on this 
input indicates the "On" duration of the ring cycle. This is a Schmitt-trigger input, 
allowing for slow rising and falling signals on this pin. 


This output controls the operation of the hookswitch relay in the DAA. The polarity of this 
output is selected by -PS pin. If -PS pin is connected to ground, this output is active 
high, i.e., it is low when the modem is on hook. During a data call, it goes high to 
operate the hookswitch relay and seize the phone line. During rotary dialing, the 
VL7C214 pulses this output at a rate of 10 pulses per second with appropriate Markl 
Space ratio depending on 212A or V.22 mode. If -PS pin is left open or connected to 
VCC, this output is active low, i.e., it is high when the modem is on hook and low during 
data call. 


A 7.3728 MHz clock signal must be connected to this input. Normally, the CKOUT pin of 
the VL7C212A modem is connected to this pin. All internal timing is derived from this 
clock. 


This pin is used to initiate writing of data to the VL7C212A modem. 


This pin is used to initiate reading of data from the VL7C212A modem. 


The VL7C214 supplies a shift clock on this pin to the VL7C212A modem for reading or 
writing data. 


The VL7C214 shifts data serially out of this pin to VL7C212A during a write operation 
and shifts data serially into this pin during a read operation from the VL7C212A. 
' 


The VL7C214 outputs serial data in asynchronous start/stop format at the data rate 
selected by the terminal. This data is either echo of commands received from the 
terminal or result codes generated by the controller during processing of the commands. 
This output is normally high and should be "AND“ed with the RXD output of the 
VL7C212A to form RXD data to the terminal. 


The VL7C214 receives command data from the terminal on this pin. The UART in the 
controller connects the serial asynchronous start/stop data into a parallel byte for 
processing by the controller. 


Ground reference (0 V). 


This input controls the polarity of KDV and OH outputs. When left open or connected to 
VCC, it forces the KDV and OH outputs to be active low. If this input is connected to 
ground, KDV and OH outputs are active high. 


When the input is open or connected to VCC, the VL7C214 sends result codes as words. 
When this input is low, result codes are sent as digits. This setting can also be changed 
by entering the V command. 


350 


$ VLSI TECHNOLOGY, INC. 


SIGNAL 
DESCRIPTIONS 


Slgnal 
Name 


-RES EN 


ECHO EN 


—AA DIS 


-CMD EN 


212A/--V.22 


MS SEL 


N.C. 


-HS 


-—AA 


—CD 


-DTR 


VCC 


Pln 
Number 


17 


18 


19 


20 


21 


22 


23 


24 


25 


26 


27 


28 


VL7C214 


(ConL) 


Slgnal 
Descrlptlon 


When this input is low, the VL7C214 sends result codes. When this input is high or left 
open, commands received from the terminal are performed but result codes are not sent. 
This setting can also be changed by entering the Q command. 


When this input is high or left open, the VL7C214 echoes characters received from the 
terminal in the command state. When this input is low, the VL7C214 will not echo char- 
acters unless it is set for half duplex and it is on line. This setting can also be changed 
by entering the E command. 


When this input is low, the VL7C214 will not answer incoming calls. When this input is 
high or left open, the VL7C214 automatically answers incoming calls on the first ring. 
This function can also be enabled/disabled by writing to the S0 register. 


When this input is low, the VL7C214 recognizes command sent to it. For some applica- 
tions such as unattended answering operation it is better to disable this function by 
leaving this input open or connecting it to VCC. 


When this input is open or connected to VCC, the VL7C214 supports Bell 103 and 212A 
modes. When this input is low, the VL7C214 supports the CCITT V.22 and V.21 modes. 
This setting can also be changed by entering the B command. 


When this input is open or connected to VCC, the Mark/Space ratio is U.S. standard, 40/ 
60 Make/Break. When it is low, the Mark/Space ratio is European standard, 33/67 Make! 
Break. 
' 


No connection 


This output, when low, indicates that the modem is in the high speed (1200 bps) mode. 
When high, it indicates that it is in the low speed (300 bps) mode. This output can be 
directly connected to a light emitting diode through a 330 Q resistor. 


This output is low when the VL7C214 is set for auto-answer mode, either by switch input 
-AA DIS (pin 19) or register S0. The output goes high during each ring. If the device is 
not set to answer the phone (pin 19 is low or S0 -= O), this output goes low each time the 
phone rings. A light emitting diode through a 330 Q resistor can be directly connected to 
this output. 


This output goes low when the VL7C214 detects a carrier signal from the remote 
modem. If the connection is broken or never established, it remains high. A light 
emitting diode can be directly connected to this output through a 330 Q resistor. 


When this input is low, the VL7C214 executes data call commands. If during a data call, 
this input goes high, the VL7C214 terminates the data call, hangs up the phone line and 
returns to command state. 


Positive supply (+5 V). 
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Register 


S0 


S1 


S2 


S3 


S4 


S5 


S6 


S7 


S8 


S9 


S10 


S11 


S12 


S13 


S14 


S15 


S16 
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TABLE 1. VL7C214 SOFTWARE REGISTERS 


Range/Unlts 


Ring to answer telephone on 


Descrlptlon 


Number of rings 


O 127 ASCII 
Escape code character 


0 127 ASCII 
Character recognized as carriage return 


Character recognized as line feedback 
0 127 ASCII 


0 32 127 ASCII 
Character recognized as back space 


Wait time for dial tone 


Wait time for carrier 


Pause time (caused by comma) 


Q. I'''II _‘ 
II N 
-h 


1 255 1/10 sec 
Carrier detect response time 


1 255 1/10 sec 
Delay between loss of carrier and hang up 


50 255 millisec 
Duration and spacing of Touch Tones 


20 255 1/50 sec 
Escape code guard time 


bit mapped 
UART status register 


bit mapped 
Option register 


bit mapped 
Flag register 


Test modes 
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Default 


0 


0 


43 (+) 


13 (ca) 


10(LF) 


8 (BS) 


2 


30 


2 


6 


7 


70 


50 


0 
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TABLE 2 COMMAND SUMMARY 


PREFIX REPEAT AND ESCAPE COMMANDS 


Command 
Descrlptlon (Notes 1 & 2) 


AT 


Al 


Attention prefix precedes all command lines except + + + (escape) and A/(repeat) commands 


Repeat last command line (Al is not followed by carnage return) 


+ + + 
Escape code 
go from on line state to command state (one second pause before and after escape 
code entry, , + + + is not followed by carnage return) 


DIALING COMMANDS 


Command 
Descrlptlon (Notes 1 & 2) 
Command 
Descr pt on 
otes 


D 


P 


T 


I 
I 
(N 
1 & 2) 


Wait for 1/8 second 


Wait for silence 


Touch Tone 
Wait for second dial tone 


Pause 
Return to command state after dialing 


Reverse mode (to call onginate only modem) 


OTHER COMMANDS 


Descrl 
Commands 
Commands 


A 


B/B0 


B1 


C/C0 


C1 


E/E0 


E1 


F/F0 


F1 


H/HO 


H1 


H2 


I/I0 


I1 


I2 


IJL1 


L2 


L3 


ptlon (Notes 
Descrlptlon (Notes 1 & 2) 


r call without waiti 


22 mode (Note 


2A mode 


Answe 


CCITT 


Bell 103 an 


ng for nng 
Speaker on until carner detected 


Speaker always on 


Go to on line state 


carner off 
Remote digital loopback off‘ 


Remote digital loopback request 


not ec 
Characte 
Result codes displayed 


Characters echoed 
Result codes not displayed 


Half duplex 
Requests current value of register r 


Full duplex 
Sets register r to value of n 


On hook (hang up) 
VNO 
Digit result codes 


Off hook, line and auxiliary relay 
Word result codes‘ 


Off hook, line relay only 
X/X 
Compatible with Hayes type 300 modems‘ 


Request product ID code (130) 
Result code CONNECT 1200 enabled 


Firmware revision number 
Enables dial tone detection 


Test internal memory 
Enables busy signal detection 


Low speaker volume 
Enables dial tone and busy signal detection 


Medium speaker volume 
Y/Y0 
Long space disconnect disabled 


High speaker volume 
Long space disconnect enabled 


M/M0 
Speaker always oft 
Software reset restores all default settings 


Notes 
1. Default modes are indicated by 
2. Commands entered with null parameters assume 0 
X is the same as X0 
3. When the ATB command is used in the answer mode, the VL7C212A is placed in either the V 21 or the V 22 mode depend 
ing on the response from the remote modem 
In the originate mode, the VL7C214 will sense if the baud rate is set at 300 or 
1200 bits 
rsecond and will ad ust the VL7C212A accordin 
I 
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TABLE 3. RESULT CODES 


Dlglt Code 
Word Code 
Descrlptlon 


0 
Command executed 


Connected at 300 or 1200 bps 
Connected at 300 bps, if result of X1 , X2, X3, or X4 command 


2 
Ringing signal detected (Note) 


3 
No Carrier 
Carrier signal not detected or lost 


1 
Connect 


Illegal command 
4 
Error in command line 
Command line exceeds buffer (40 characters, including punctuation) 
Invalid character format at 1200 bps 


5 
Connect 1200 
Connected at 1200 bps. Results from X1, X2, X3, or X4 commands only 


6 
No D 
no 
Dialtone not detected and subsequent commands not processed 
'a 
ne 
Results from X2 or X4 commands only 


7 
B 
Busy signal detected and subsequent commands not processed 
usy 
Results from X3 or X4 commands only 


8 
No Answer 
Silence not detected and subsequent commands not processed 
Results from @ command only 


Note : When the VL7C214 detects a ringing on the telephone line, it sends a RING result code. However, the VL7C214 
will answer the call only if it is in auto-answer mode or is given an A command. 
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ABSOLUTE 
MAXIMUM 
RATINGS 
Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. Expo- 
Temperature 
0°C to +70°C 
permanent damage to the device. 
sure to absolute maximum rating 
Storage Temperature 
455°C re H5006 
These_are stress ratings only, functional 
conditions for extended periods may 
operation of this device at these or any 
affect device reliability. 
SUPPIY v°IIa9"j I° 
other conditions above those indicated 
Ground Potential 
+6 V 


Applied Input 
Voltage 
-0.6 V to VCC + 6 V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = 0 to +70 <>c, vcc = s v 110% 


Svm*=°' 
%@% 
°<="<*"'<>"= 
VCC 
iii 
i 
=<=<= 
jnmjlmi 
@vc¢-sv.~~~@ad@d 
vii 
EIZII 
Aiimpi-RI 
vi 
111211 
A~~mpi-R- 
VT+ 
I111 
~=ipi~ 
w- 
iii 
~=i~»i~ 
volt 
111 
@ioH--M 
VOL 
ii 
@~<>i-MA 
ii 
ii 
FCLK 
@ 
Note : This applies to all pins except TEST, which has an internal pull-down -WR, -RD, SCK, DVO, and switch input pins 
15 thru 21 which have internal pull-ups. 


<<<<< 


F 
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FIGURE 1 . 212AlV.22 STAND-ALONE INTELLIGENT MODEM USING THE VL7C212A MODEM IC 
AND THE VL7C21 4 


+5V 


ff 
sec Q 


CD 


RD 


TR 
ff 
seon 
IIF. 
IIII 
MR 
ff 
sec Q 
- 
HS 


OH 


SD 


AA 
VL7C214 


(WORDRES.) 
SW 
'6 
SWl.1 


<HEs.E~> 
SW3 
*7 
SWl.2 


IECHQON) 
SW4 
'8 
SWL3 


(AA Dis) 
SW5 
SWl.4 
-1.(D 


(CNWHJEN) 
S“”5 


(212/\) 
SW9 
2‘ 
SWl.6 


(ewe UP RES) 
$Wl° 
22 
Sw|_7 


' 
3 
TEST 


GND 


__i_=_ixo vcc 
E5 
AA 
. 


CONTROLLER 


W 
'0? HIIII 


HS 
bi‘ 


TXD 


DI/O 


SCK 
R6 
"W 


CLK 


KDVIIIIE 


1 
2 
15 
23 
4 


Note: Schematics are for illustration purposes only. Operational systems may require modifications. 
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FIGURE 1. 212AN.22 STAND-ALONE INTELLIGENT MODEM USING THE VL7C212A MODEM ic 
AND THE VL7C214 (Cont.) 
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FEATURES 
- 
Direct interface to VL7C212A single- 
chip modems 


- Complete Hayes AT command set in 
firmware 


- Built-in UART 


- Direct IBM PC bus interface 


~ IORDY pin for use on high-speed 
buses 


- Two-micron 


- Complete intelligent modem in two ICs 


- Compatible with industry-standard 
software 


CMOS process 


- Replacement for Sierra SC11017 


- Reduces board space and component 
count requirements 


DESCRIPTION 
The VL7C215 Parallel Bus Modem 
Controller is specifically designed to 
control the VL7C212A single-chip, 300/ 
1200 bit-per-second modem. Built with 
an advanced two-micron CMOS 
process, the VL7C215 provides a 
highly cost effective solution for 
interlacing a modem IC to a system 
bus. When connected to the 
VL7C212A, with the addition of a data 
access arrangement (DAA), the 
VL7C215 implements a Hayes-type 
smart modem for board-level, integral- 
modem applications. Because the 
VL7C215 fully emulates the functional- 
ity of the VL82C50 UART and includes 
data bus transceivers, it can be directly 
interlaced to a computer's parallel data 


HIGH SPEED PARALLEL BUS MODEM CONTROLLER 


bus (in particular to the bus of the IBM 
PC, XT or AT). All of the popular com- 
munications software written for the PC 
will work with the VL7C215/ 
VL7C212A chip set. In addition to 
including the functionality of the 
VL82C50 UART, the VL7C215 contains 
an 8-bit microprocessor, 8K by 8 bits of 
ROM and 128 by 8 bits of RAM. 


For specific high-volume applications, 
the control program can be modified by 
VLSI to include additional command 
functions. 


PIN DIAGRAMS 
BLOCK 
DIAGRAM 


-oosT 
-DIST -__> 
UART 
-cs ?—-> 
A0 - A2 
UART 
BAUD RATE 
TRANS 
TXD 
IORDY 
INTERFACE 
[)0 - [)7 
p1EG|$"|'ER5 
INT CONT 
RCVR 
RXD 


UART MONITOR 
UART CONTROL 
REGISTER 
REGISTER 


-DOST 
-DIST 
IORDY 
KDV 
-at 
on 
CLK 
-we 
-no 
SCK 
0 I/O 
TXD 
nxo 
GND 


XU 


VL7C215 
1 
28 VCC 
2 
27 -CS 
3 
26A2 
4 
25 A1 
5 
24 A0 
6 
23INT 
7 
22 
D7 
8 
21D6 
9 
20 
D5 
10 
19D4 
11 
18 
D3 
12 
17 
D2 
13 
16 
D1 
14 
15DO 


IORDY -DOST 
-CS 
v|-0isT| vccl 
A2 
IIIIIII 
402 
20 
—Rl5 
one 
cu<1 
-was 
-nos 
SCK10 
ovo11 


128 
27 
. 
25 


24 I 


23 I 


TOP VIEW 
22 I 


21 I 


20 I 
19 
3 
415117 


TXD 
GND 
D1 


RXD 
III 
M 
ORDER 


Part 
' 
_wr1 
Number 
VL7C21 5-PC 
Package 
Plastic DIP 


'“T i 


ROM BLOCK 
PC/SUBROUTINE 
REGISTER 
STACK 


ROM 
8KX 8 
\J 


VL7C215-QC 
Plastic Leaded Chip Carrier (PLCC) 
Note: Operating temperature range is 0°C to +70°C. 
KDV 
OH 
-RI 
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D3 
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Slgnal 
Name 


-DOST 


-DIST 


IORDY 


KDV 


-RI 


OH 


cu< 


-we 


-no 


SCK 


DI/O 


Pln 
Number 


1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


Slgnal 
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The CPU can write data or controlwords into a selected register of the VL7C215 when 
-DOST is low and the chip is selected. Data is latched on the rising edge of the signal. 


The CPU can read data or status information from a selected register of the VL7C215 
when -DIST is low and the chip is selected. 


This open-drain output will go low upon a write or read operation, and remain low until 
internal data setup and hold times have been satisfied. 


This output controls the operation of the data/voice relay. When low, the data/voice relay 
is off and the phone line is connected to the phone set. During a data call, the VL7C215 
makes this output high to operate the data/voice relay, disconnecting the phone set from 
the phone line. It may also be used to drive a relay for multi-line phone applications to 
close the A and A1 leads. 


The output of the ring detector in the DAA is connected to this input. A low level on this 
input indicates the "On" duration of the ring cycle. This is a Schmitt-trigger input, 
allowing for slow rising and falling signals on this pin. 


This output controls the operation of the hookswitch relay in the DAA. During a data call, 
this output is high. It operates the hookswitch relay which causes the phone line to be 
seized. During rotary dialing, the VL7C215 pulses this output at a rate of 10 pulses per 
second with appropriate Mark/Space ratio depending on 212A or V.22 mode. 


_A 7.3728 MHz clock signal must be connected to this input. Normally, the CKOUT pin of 
the VL7C212A modem is connected to this pin. All internal timing is derived from this 
clock. This clock must be adjusted to within 0.01%. 


This pin is used to initiate writing of data to the VL7C212A modem. On power-up, it is an 
input for a brief time in which the VL7C215 reads the carrier status switch connected to 
this pin. If the switch is closed to ground through an 18 Kn resistor, the VL7C215 sets 
the Received Line Signal Detect (RLSD) Bit in the Modem Status Register. If the switch 
is open, the VL7C215 resets this bit and writes the actual status of the carrier detector 
during a data call. If no switch is used, an internal pull-up sets the status during power- 
up to the default state (pull-up to VCC) which is to follow the remote modem's carrier. 


This pin is used to initiate reading of data from the VL7C212A modem. On power-up, 
this pin is an input for a brief time in which the VL7C215 reads the DTR status switch 
connected to this pin. If this switch is open, the VL7C215 reacts to the status of the DTR 
bit in the UART Modem Control Register. If the switch is closed to ground through 18 
kn, the VL7C215 ignores the state of the DTR bit. When the switch is open, writing a 
zero to the DTR bit in the Modem Control Register forces the VL7C215 into the com- 
mand state and when on-line, causes it to hang up. If no switch is used, an internal pull- 
up to VCC sets the status during power-up to the default state (to follow the DTR status). 


The VL7C215 supplies a shift clock on this pin to the VL7C212A modem for reading or 
writing data. On power-up, this pin is an input for a brief time in which the VL7C215 
reads the Bell/CCITT select switch connected to this pin. If this switch is open, Bell 
protocol is selected. If this switch is closed to ground through18 kn, CCITT V.22 
protocol is selected. If no switch is used, an internal pull-up sets the status during 
power-up to the default state (212A mode). 


The VL7C215 shifts data serially out of this pin to VL7C212A during a write operation 
and shifts data serially into this pin during a read operation from the VL7C212A. On 
power-up this pin is an input for a brief time in which the VL7C215 reads the Make/Break 
ratio select switch connected to this pin for selecting the pulse dialing standard. With the 
switch open, the Bell standard 39% Make, 61% Break is selected. With the switch 
closed to ground through 18 kn, the CCITT standard 33% Make, 67% Break is selected. 
If no switch is used, an internal pull-up sets the status during power-up to the default 
state (Bell standard). 
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Slgnal 
Pln 
Number 
Name 


TXD 


RXD 


GND 


D0-D7 


INT 


A0-A2 


-CS 


VCC 


12 


13 


14 


15-22 


23 


24-26 


27 


28 


Slgnal 
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This pin is a serial output pin. During a data call, alter the connection is established, the 
VL7C215 converts parallel data received from the computer bus and outputs it in a 
serial, asynchronous format to the VL7C212A modem for modulation. At all other times 
the VL7C215 holds this output in the Mark (high) condition. 


Demodulated data from the VL7C212A modem is received on this pin during a data call. 
A high level is considered Mark and a low level is Space. The VL7C215 converts the 
serial data into a parallel data byte and stores it in the Receiver Buffer Register (RBR). 
The Data Ready bit in the Line Status Register (LSR) is then set, and an appropriate 
interrupt identification code is written in the Interrupt Identification Register (IIR) to signal 
to the computer, the reception of a new data byte. 


Ground reference (0 V). 


This is the 8 bit data bus comprising of three-state input/output lines. This bus provides 
bidirectional communication between the VL7C215 and the CPU. Data control words 
and status information are transferred via the D0 - D7 data bus. 


This output goes high whenever any one of the following interrupt types has an active 
condition and is enabled via the IER: Receiver Line Status flag, Received Data Avail- 
able, Transmitter Holding Register Empty, and Modem Status. It is reset low upon the 
appropriate interrupt servicing. The INT pin is forced to a high impedence state when 
the OUT2 bit of the Modem Control Regiser (MCR) is low (power on state). 


These three address inputs are used during read or write operation to select a UART 
register in the VL7C215 as shown in Table 1. The Divisor Latch Access Bit (DLAB) must 
be set high by the system software to access the bit rate divisor latches as shown in 
Table 2. 


The VL7C215 is selected when this input is low. When high, the VL7C215 forces the 
Data bus lines into a high impedance state. 


Positive supply (+5 V). 


TABLE 1. VL7C215 UART REGISTERS 
:a|r.|m@ 


O 
O 
O 
O 


O 


0 


X 


X 


>-(XXX 


O 
O 
O 


0 
O 
1 


0 
1 
0 


O 
1 
1 


1 
O 
O 


1 
O 
1 


1 
1 
O 


1 
1 
1 


1 
O 
O 
O 


1 
O 
O 
1 


RBR 


THR 


IER 


IIR 


LCR 


MCR 


LSR 


MSR 


STR 


DLL 


DLM 


Receiver Buffer Register (read only) 


Transmitter Holding Register (write only) 


Interrupt Enable Register 


Interrupt Identification Register (read only) 


Line Control Register 


Modem Control Register 


Line Status Register 


Modem Status (read only) Register 


Speed 


Divisor Latch (LSB) (write only) 


Divisor Latch (MSB) (write only) 


X - "Don't Care” 
O -= Logic Low 
1 -= Logic High 
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FIGURE 1. UART BLOCK DIAGRAM 
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TABLE 2. VL7C215 UART REGISTER FUNCTION SUMMARY 


Regret" 
Reglster Blt Number 
'“"°'“°"'° 
Bt0 
en 
e12 
era 
B14 
Bt5 
ere 
BIt7 


C) 
C)O 


RBR 
Data 


THR 
Data 


|ER 
Receive 
THRE 
Receive 
Modem 
Data 
Interrupt 
Line 
Status 
Available 
Enable 
Status 
Interrupt 
Interrupt 
Interrupt 
Enable 
Enable 
Enable 


||R 
0 If 
Interrupt 
Interrupt 
Interrupt 
ID Bit 0 
ID Bit 1 
Pending 


LCR 
O = 7 Bit 
1 
0 = 1 Stop 
1 =- Parity 
1 =- Even 
1 =- Stick 
1 - Set 
DLAB 
Data 
Bit 
Enable 
Parity 
Parity 
Break 


1 =- 8 Bit 
1 = 2 Stop 
Data 
Bits 


MCR 
Data 
Request 
OUT1 
OUT2 
No 
0 
Terminal 
to Send 
0 - INT 
Function 
Ready 
8 
Output 
to HI-Z 


LSR 
Data 
Overrun 
Parity 
Framing 
Break 
THRE 
TSRE 
Ready 
Error 
Error 
Error 
Interrupt 


MSR 
Trailing 
Delta 
1(CTS) 
1 
DSR) 
RLSD 
Edge Ring 
RLSD 


DLM 
Data 


DLL 
Data 


STR 
Data 
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Reglster 


S0 


S1 


S2 


S3 


S4 


S5 


S6 


S7 


S8 


S9 


S10 


S11 


S12 


S13 


S14 


S15 


S16 
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Range/UnIts 
Descrlptlon 
TABLE 3. VL7C215 SOFTWARE REGISTERS 


Rmg to answer telephone on 


Number of rmgs 


0 127 ASCII 
Escape code character 


0 127 ASCII 
Character recogn|zed as carnage return 


0-127 ASCII 
Character recogmzed as I|ne feedback 


0 32 127 ASCII 
Character recogmzed as back space 


Walt t|me for d|a| tone 


Wan trme for carner 


Pause llIT‘|8 (caused by oomma) 


1 255 1/10 sec 
Carrler detect response t|me 


1 255 1/10 sec 
Delay between loss of carrler and hang up 


50 255 m|ll|sec 
DUl’8IIO and spacrng of Touch Tones 


20 255 1/50 sec 
Escape code guard tame 


but mapped 
UART status reg|ster 


but mapped 
Optron reg|ster 


blt mapped 
Flag reg|ster 


.°... I~ :- 
1 
Test modes 
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Default 


0 


0 


43 (+) 


13 (CR) 


10 (LF) 


8 (BS) 


2 


30 


2 


6 


7 


70 


50 


0 
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TABLE 4. COMMAND SUMMARY 


PREFIX, REPEAT AND ESCAPE COMMANDS 


Command 
Descrlptlon (Notes 1 & 2) 


AT 
Attention prefix: precedes all command lines except + + + (escape) and A/(repeat) commands 


Al 
Repeat last command line (Al is not followed by carriage return) 


+ + + 
Escape code: go from on-line state to command state (one second pause before and after escape 
code entry; ; + + + is not followed by carriage return) 


DIALING COMMANDS 


Commend 
Descrlptlon (Notes 1 & 2) 


D WW1/8 second 
P l wan for silence 


T 
Touch Tone 
Wait for second dial tone 


, 
Pause 
Return to command state after dialing 


-ro 


l 
Flash 
Reverse mode (to call originate-only modem) 


OTHER COMMANDS 


Commands 
Descrlptlon (Notes 1 & 2) 
Commands 
Descrlptlon (Notes 1 & 2) 


A 
Answer call without waiting tor ring 
Speaker on until carrier detected’ 


B/B0 
CCITT V 22 mode (Note 3) 
Speaker always on 


B1 
Bell 103 and 212A mode 
Go to on-line state 


C/C0 
Transmit carrier off 
Remote digital loopback off‘ 


C1 
B 
Remote digital loopback request 


E/E0 
Result codes displayed’ 


E1 
Result codes not displayed 


F/F0 
Requests current value of register r 


F1 
Sets register r to value of n 


WHO 
Digiiresuiicodes 
H1 
wordresuii 


H2 
Compatible with Hayes-type 300 modems’ 


VIO 
Result code CONNECT 1200 enabled 


I1 
Enables dial tone detection 


I2 
Enables busy signal detection 


UL1 
Enables dial tone and busy signal detection 


L2 
Long space disconnect disabled‘ 


L3 
Long space disconnect enabled 


M/M0 
Software reset: restores all default settings 
Notes: 
1. Default modes are indicated by ‘. 
2. Commands entered with null parameters assume 0 - X is the same as X0. 
3. When the ATB command is used in the answer mode, the VL7C212A is placed in either the V.21 or the V.22 mode, depend- 
ing on the response from the remote modem. In the originate mode, the VL7C215 will sense if the baud rate is set at 300 or 
1200 bits per second and will adjust the VL7C212A accordingly. 
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TABLE 5. RESULT CODES 


Dlglt Code 


1 
Connect 


2. 


3 
No Carrier 


4 


5 
Connect 1200 


6 
No Dialtone 


7 
Busy 


8 
No Answer 


Word Code 


C) 
Command executed 


Connected at 300 or 1200 bps 


Ringing signal detected (Note) 


Carrier signal not detected or lost 


Illegal command 
Error in command line 


VL7C215 


Descrlptlon 


Connected at 300 bps, if result of X1, X2, X3, or X4 command 


Command line exceeds buffer (40 characters, including punctuation) 
Invalid character format at 1200 bps 


Results from X2 or X4 commands only 


Results from X3 or X4 commands only 


Results from @ command only 


Connected at 1200 bps. Results from X1 , X2, X3, or X4 commands only 


Dialtone not detected and subsequent commands not processed 


Busy signal detected and subsequent commands not processed 


Silence not detected and subsequent commands not processed 


Note: When the VL7C215 detects a ringing on the telephone line, it sends a RING result code. However, the VL7C215 
will answer the call only if it is in auto-answer mode or is given an A command. 


TABLE 6. RESET CONTROL OF REGISTERS AND PINOUT SIGNALS 


Reglster/Slgnal 


9 
Receiver Buffer Register 


Transmitter Holding Register 


Interrupt Enable Register 


Interrupt Identification Register 


Line Control Register 


MODEM Control Register 


Line Status Register 


Modem Status Register 


Divisor Latch (high order bits) 


TXD 


INT 



Reset Control 


irst word received 


Writing into the Transmitter Holding Register 


ower on reset 


Power on reset 


Writing into the LCR 


Power on reset 


Power on reset 


Power on reset 


Power on reset 


Master reset 


Power on reset 
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Reset State 


Data 


Data 


All bits low 


Bit 0 high; 
bits 1-7 low 


Data 


All bits low 


Bits 0-4, 7 low; 
bits 5-6 high 


Bits 0-3, 6-7 low; 
bits 4-5 high 


1200 bps 


High 


Low (high impedence) 
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UART 
REGISTERS 
Llne Control Registers 
This register controls the format of the 
asynchronous data communications. 


Bit O and 1: Bit 1 is always high. Bit 0 
specifies the number of bits in each 
transmitted or received serial character. 
The encoding of bit 0 is as follows: 


Bit 1 
Bit 0 
Word Length 


1 
0 
7 Bits 


1 
1 
8 Bits 


Bit 2: This bit specifies the number of 
Stop bits in each transmitted or re- 
ceived serial character. If bit 2 is a logic 
0, one Stop bit is generated or checked 
in the transmit or receive data, respec- 
tively. If bit 2 is a logic 1, when 7-bit 
word length with no Parity is selected, 
two Stop bits are generated or checked. 


Bit 3: This bit is the Parity Enable bit. 
When bit 0 is a logic 0 and bit 3 is a 
logic 1, a Parity bit is generated 
(transmit data) or checked (receive 
data) between the last data word bit and 
the Stop bit of the serial data. (The 
Parity bit is used to produce an even or 
odd number of 1s when the data word 
bits and the Parity bit are summed.) 


Bit 4: This bit is the Even Parity Select 
bit. When bit 3 is a logic 1 and bit 4 is 
logic 0, and odd number of logic 1s is 
transmitted or checked in the data word 
bits and Parity bit. When bit 3 is logic 1 
and bit 4 is a logic 1, an even number of 
bits is transmitted or checked. 


Bit 5: This bit is the Stick Parity bit. 
When bit 3 is logic 1 and bit 5 is logic 1, 
the Parity bit is transmitted and then 
detected by the receiver in the opposite 
state indicated by bit 4. 


Bit 6: This bit is the Set Break Control 
bit. When bit 6 is a logic 1, the serial 
output (TXD) is forced to the Spacing 
state (logic 0) and remains there (until 
reset by a low-level bit 6) regardless of 
other transmitter activity. The feature 
enables the CPU to alert a terminal in a 
computer communications system. 


Bit 7: This bit is the Divisor Latch 
Access Bit (DLAB). It must be set high 
(logic 1) to access the Divisor Latches 
of the Baud Rate Generator during a 
Read or Write operation. It must be set 
low (logic 0) to access the Receiver 
Buffer, the Transmitter Holding Regis- 
ter, or the Interrupt Enable Register. 


Programmable Baud Rate Generator 
The VL7C215‘s Baud Rate Generator 
can be programmed for one of six baud 
rates. The desired speed is selected by 
writing into the Divisor Latch (DLM) . 
On reset, the rate will be 1200 baud. 


DLM (Hex Code) 
Baud Rate 
00 
1200 


- 
01 
300 
03 
150 
04 
110 
06 
75 
09 
50 


Llne Status Reglster 
This 8-bit register provides status 
information to the CPU concerning the 
data transfer. The contents of the Line 
Status Register are indicated in Table 2 
and are described below: 


Bit 0: This bit is the receiver Data 
Ready (DR) indicator. Bit 0 is set to a 
logic 1 whenever a complete incoming 
character has been received and 
transferred into the Receiver Buffer 
Register. Bit 0 will reset to a logic 0 
either by the CPU reading the data in 
the Receiver Buffer Register or by 
writing a logic 0 into it from the CPU. 


Bit 1: This bit is the Overrun Error (OE) 
indicator. Bit 1 indicates that data in the 
Receiver Buffer Register was not read 
by the CPU before the next character 
was transferred into the Receiver Buffer 
Register, thereby destroying the 
previous character. The OE indicator is 
reset whenever the CPU reads the 
contents of the Line Status Register. 


Bit 2: This bit is the Parity Error (PE) 
indicator. Bit 2 indicates that the 
received data character does not have 
the correct even or odd parity, as 
selected by the even parity select bit. 
The PE bit is set to a logic 1 upon 
detection of parity error and is reset to a 
logic 0 whenever the CPU reads the 
contents of the Line Status Register. 


Bit 3: This bit is the Framing Error (FE) 
indicator. Bit 3 indicates that the 
received character did not have a valid 
Stop bit. Bit 3 is set to a logic 1 
whenever the Stop bit following the last 
data bit or parity bit is detected as a 
zero (Spacing level). 


Bit 4: This bit is the Break Interrupt (BI) 
indicator. Bit 4 is set to a logic 1 
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whenever the received data input is 
held in the Spacing (Logic 0) state for 
longer than a full word transmission 
time - the total time of Start bit + data 
bits + Parity + Stop bits. 


Bit 5: This bit is the Transmitter Holding 
Register Empty (THRE) indicator. Bit 5 
indicates that the VL7C215 is ready to 
accept a new character for transmis- 
sion. In addition, this bit causes the 
VL7C215 to issue an interrupt to the 
CPU when the Transmit Holding 
Register Empty enable is set high. The 
THRE bit is set to a logic 0 concurrently 
with the loading of the Transmitter 
Holding Register by the CPU. 


Bit 6: This bit is the Transmitter Shift 
Register Empty (TSRE) indicator. Bit 6 
is set to a logic 1 whenever the Trans- 
mitter Shift Register is idle. It is reset to 
logic 0 upon a data transfer from the 
Transmitter Holding Register to the 
Transmitter Shift Register. 


Bit 7: This bit is permanently set to 
logic 0. 


Bits 1 through 4 are the error conditions 
that produce a Receiver Line Status 
interrupt whenever any of the corre- 
sponding conditions are detected. 


Interrupt ldentlcatlon Reglster 
The VL7C215 has an on-chip interrupt 
capability that allows for complete 
flexibility in interfacing to all popular 
microprocessors. To provide minimum 
software overhead during data charac- 
ter transfers, the VL7C215 prioritizes 
interrupts into four levels. The four 
levels of interrupt conditions are as 
follows: Receiver Line Status (priority 
1); Received Data Ready (priority 2); 
Transmitter Holding Register Empty 
(priority 3); and MODEM Status (priority 
4). 


Information indicating that a prioritized 
interrupt is pending the source of that 
interrupt are stored in the Interrupt 
Identification Register (refer to Table 7). 
The Interrupt Identification Register 
(IIR), when addressed during chip- 
select time, freezes the highest priority 
interrupt pending and no other inter- 
rupts are acknowledged until the 
particular interrupt is serviced by the 
CPU. The contents of the IIR are 
indicated in Table 2 and are described 
below. 


Bit 0: This bit can be used in either a 
hardwired prioritized or polled environ- 
ment to indicate whether an interrupt is 
pending. When bit 0 is logic 0, an 
interrupt is pending and the IIR contents 
may be used as a pointer to the 
appropriate interrupt service routine. 
When bit 0 is a logic, no interrupt is 
pending. 


Bits 1 and 2: These two bits of the IIR 
are used to identify the highest priority 
interrupt pending as indicated in Table 
7. 


Bits 3 through 7: These five bits of the 
IIR are always logic 0. 


Interrupt Enable Reglster 
This 8-bit register enables the four 
interrupt sources of the VL7C215 to 
separately activate the Interrupt (INT) 
output signal. It is possible to totally 
disable the interrupt system by resetting 
bits 0 through 3 of the Interrupt Enable 
Register. Similarly, by setting the 
appropriate bits of this register and the 
active (high) INT output from the chip. 
All other system functions operate in 
their normal manner, including the 
setting of the Line Status and MODEM 
Status Register. The contents of the 
Interrupt Enable Register are indicated 
in Table 2 and are described below. 


Bit 0: This bit enables the Received 
Data Available Interrupt when set to 
logic 1. 


Bit 1: This bit enables the transmitter 
Holding Register Empty Interrupt when 
set to a logic 1. 
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Bit 2: This bit enables the Receiver 
Line Status Interrupt when set to logic 
1. 


Bit 3: This bit enables the MODEM 
Status Interrupt when set to logic 1. 


Bit 4 through 7: These four bits are 
always logic O. 


MODEM Control Reglster 
This 8-bit register controls the interface 
with the MODEM. The contents of the 
MODEM Control Register are indicated 
in Table 2 and are described below. 


Bit 0: This bit controls Data Terminal 
Ready (DTR) signal. If the external 
switch on the -RD pin is set to VCC 
through an 18 kQ resistor, setting the 
DTR low will force the VL7C215 into the 
command state and if on line, it will 
hang up. 


Bit 1: This bit controls the Request to 
Send (RTS) signal. This signal is not 
used by the VL7C215. 


Bit 2: This bit controls the Output 1 
(OUT1) signal. This signal is not used 
by the VL7C215. 


Bit 3: This bit controls the Output 2 
(OUT2) signal. When OUT2 is a 0, the 
interrupt output is in high impedence 
state. 


Bit 4: Not used. 


Bits 5 through 7: These bits are 
permanently set to logic 0. 


MODEM Status Reglster 
This 8-bit register provides the current 
state of the control lines from the 
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MODEM (or peripheral device) to the 
CPU. In addition to this current-state 
information, two bits of the MODEM 
Status Register provide change 
information. These bits are set to a 
logic 1 whenever a control input from 
the MODEM changes state. They are 
reset to logic 0 whenever the CPU 
reads the MODEM Status Register. 


The contents of the MODEM Status 
Register are indicated in Table 2 and 
are described below. 


Bits 0 and 1: These bits are always 0. 


Bit 2: This bit is the Trailing Edge of 
Ring Indicator (TERI) detector. Bit2 
indicates that the -RI input to the chip 
has changed from On (logic 1) to an Off 
(logic 0) condition. 


Bit 3: This bit is the Delta Received 
Line Signal Detector (DRLSD) indicator. 
Bit 3 indicates that the carrier detector 
has changed state. 


Bit 4: This bit is always 1. 


Bit 5: This bit is always 1. 


Bit 6: This bit is the complement of the 
Ring Indicator (-RI) input. 


Bit 7: This bit is the Received Line 
Signal Detect (RLSD) signal. 


Whenever bit 2 is set to logic 1, or bit 3 
changes state, a MODEM Status 
Interrupt is generated if enabled. 
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TABLE 7. INTERRUPT CONTROL FUNCTIONS 


Interrupt 
Identlflcatlon 
Reglster 


Blt 2 


OC) 
—*—*O 


Interrupt Set and Reset Functions 


Prlorlty 
Interrupt 
Level 
Interrupt Flag 
Interrupt Source 
Reset comm‘ 


Receiver 
Overrun Error or 
Reading the Line 
Line Status 
Parity Error or 
Status Register 
Framing Error or 
Break Interrupt 


Second 
Received Data 
Received Data 
Reading the Receiver 
Available 
Available 
Buffer Register 


Third 
Transmitter Holding 
Transmitter Holding 
Reading the IIR (if source of 
Register Empty 
Register Empty 
interrupt) or Writing into the 
Transmitter Holding Register 


Fourth 
Ring Indicator or 
Reading the MODEM 
Received Line 
Status Register 
Signal Detect 
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FIGURE 2. ADDRESS DECODER CIRCUIT 
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AC CHARACTERISTICS: TA = o TO 1o<>c, vcc -.= s v 1:1 0% 


Symbol 
Parameter 


tDIW 
-DIST Strobe Width 


Read Cycle Delay 


Read Cycle -= tDIW + tRC + 


Delay from —DIST to Data 


—DIST to Floating Data Delay 


tDOW 
-DOST Strobe Width 


tWC 


E 
3°55N 
Q0 


20 ns 


tDDD 


Write Cycle Delay 


Write Cycle = tDOW + tWC + 20 


Data Setup ‘lime 


Data Hold Time 


tDlC 
-DIST Delay from Select 


tDOC 
-DOST Delay from Select 


tACR 
Address and Chip Select Hold Time from —DlST 


tACW 
Address and Chip Select Hold Time from -DOST 


tDIOR 
-DIST/-DOST to IORDY Dela 


tWlOR 
IORDY Pulse Width 
Recelver 


RS 


562 IUJO 


tRlNT 
Delay from -DIST (Read RBR) to Reset Interrupt 
100 pF Load 


Transmitter 


tHR 
Delay 


tlRS 


from -DOST (Write THR) to 


Delay from Initial INTR Reset to Transmit Start 


Delay from Initial Write to Interrupt 


Reset Interrupt 


tSS 
Delay from Stop to Next Start 


tSTI 
' 
Delay from Stop to 
(THRE) 


tlR 
Delay from -DIST (Read IIR) to Reset Interrupt (THRE) 


Note: A TTL load is 40 uA sourced and -1.6 mA sinked current. 


Interrupt 


371 


YQ 


-~ca 


-oiNooo 


TBD 


TBD 


Baud Cycle 


Baud Cycle 


Baud Cycle 


VL7C21 5 


Condltlons 


1'lTL Load 


1'lTL Load 


1TTL Load 


1TTL Load 


1'l'l'L Load 


1TTL Load 


1'l'l'L Load 


1'ITL Load 


1'lTL Load 


1TTL Load 


1'l'l'L Load 


1'l'I'L Load 


1TTL Load 


1TTL Load 


1Tl'L Load 


1TTL Load 


100 pF Load 


100 pF Load 


FIGURE 3. READ CYCLE TIMING 
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FIGURE 4. WRITE CYCLE TIMING 
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FIGURE 5. RECEIVER TIMING 
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FIGURE 6. TRANSMITTER TIMING 
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ABSOLUTE 
MAXIMUM 
RATINGS 


Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. Expo- 
Temperature 
0°C to -i-70°C 
permanent damage to the device. 
sure to absolute maximum rating 
Storage Temperature 
455°C to +1 50°C 
These are stress ratings only, functional 
conditions for extended periods may 
S 
I 
V It 
t 
operation of this device at these or any 
affect device reliability. 
“pp Y 
° 39° ° 
other c nd't' ns above those indicated 
Ground Potential 
+6 V 
O 
I lo 


Applied Input 
Voltage 
-0.6 V to VCC +0.6 V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA =-. 0 to +70 =>c, vcc = s v 110% 
, 
Svmb~' 
lE% 
°°"<*'"=="='- 
VCC 
E3 
=<=<> 
it 
@v<>c-sv 
W 
EIZII 
Ali-X--A-Rt 
I 
- 
<<<< 


VIL 
Low Level Input Voltage 
All pins except -RI 


VT+ 
Positive Hysterisis Threshold 
—Rl pin 


VT-- 
Negative Hysterisis Threshold 
-RI pin 


__ 
Digital signal pins D0 to D7 


VOH 
High Level Output Voltage 
VCC 
1-0 
and INT @ IOH = -6 mA 
VG 
_1 0 
- 
gIIl(2§I|1{8iOLéII)nUAOf I/O Pins 


Digital signal pins D0 to D7 
VOL 
L 
L 
V 
and INT @ IOL = e mA 
IO t 
t V It 
ow 
eve 
U pu 
O age 
V 
All other output or I/O pins 
@ IOL = 2 mA 


IL 
Leakage Current (Note) 
d:1.0 


FCLK 
Clock Fre uenc 
7 3721 
7 3728 
7 3735 
q 
y 
. 
. 
. 


Note : 
This applies to all pins except TEST, which has an internal pull-down -WR, -RD, SCK, DI/O and switch input pins 
which have internal pull-ups. 
EH 
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FIGURE 7. INTEGRAL SMART MODEM CONFIGURATION FOR PC BUS APPLICATIONS 
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FEATURES 
- Complete 2400 bit-per-second 
modem conforming to V.22 bis speci- 
caons 


- Compatible with CCITT V.22 bis, 
V.22, V.21 and BELL 212A and 103 
standards 


~' Integrated DTMF/GUARD TONE 
GENERATOR, call progress monitor 
and contains an on-chip hybrid 


- Analog, digital and remote digital 
loopback 


- Programmable audio output port 


- Three-micron CMOS technology 


- DIP or PLCC package 


- High-level of integration provides for 
economical 2400 bit-per-second 
modem solution 


PIN DIAGRAMS 
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2400 BIT-PER-SECOND MODEM 


- Broadly adaptable to established 
worldwide standards at 2400, 1200 
and 300 bits-per-second 


- Minimizes need for external compo- 
nents simplifying design of intelligent 
modems 


- Testable signal path diagnostics 


- Audio interface for phone line 
monitoring 


- Low power consumption 


DESCRIPTION 
The VL7C224A is a complete 2400 bit- 
per-second modem IC containing all 
modem functions except the adaptive 
equalizer. 
It is used in conjunction 
with an external controller such as the 
VL7C235 (for parallel bus applica- 
tions), the VL7C245 (for RS-232 appli- 
cations) or a general purpose micro- 
controller such as 8096, to implement 


a 2400 bps full duplex modem, compat- 
ible with the CCITT V.22 bis recommen- 
dation. The controller performs all 
modem control and handshaking 
functions as well as the adaptive 
equalization. 


The VL7C224A operates in 2400 bps 
OPSK/OAM and 1200 bps PSK as well 
as 0 to 300 baud FSK modes, compat- 
ible with Bell 103 and 212A as well as 
CCITT V.21, V.22 and V.22 bis stan- 
dards. When used with the VL7C225, 
VL7C235, or VL7C245 controllers, the 
VL7C224A becomes an intelligent 
modem controlled by the industry 
standard “AT” command set. The 
interface between the VL7C224A 
modem and the controller (either the 
8096 or the VL7C225/235/245) is a 
standard microcontroller interface that 
easily connects to an EEPROM for 
permanent storage of configuration 
settings and phone numbers. 
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ORDER INFORMATION 


Part 
Number 
Package 
VL7C224A-PC 
Plastic DIP 
VL7C224A-QC 
Plastic Leaded Chip Carrier (PLCC) 


Note:Operating temperature range is 0°C to +70°C. 
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FIGURE 1 
BLOCK DIAGRAM 
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SIGNAL DESCRIPTIONS 


Slgnal 
Name 
Pln 
Number 
Slgnal 
Descpon 
SCR 


AGND 
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22 


23 


24 


25 
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28 


Synchronous Clock Receive (Data set source) - A TTL output that is used only in bit 
synchronous mode. It's recovered by the receiver phase locked loop from the far end 
modem. Data on RX is valid at the rising edge of this clock. 


Analog Ground 


Synchronous Clock Transmit (Data set source) - This TIL output is used only in bit 
synchronous mode and is generated internally by the VL7C224A clock generator. Rate 
... 1200 Hz :t 0.01% or 2400 Hz :1: 0.01%. 


Synchronous Clock Transmit Element (DTE source) - TTL input used only in bit synchro- 
nous locked mode and data on TXD line is latched by the VL7C224A at the rising edge 
of this clock. Clock rate =- 1200 Hz i 0.01% or 2400 Hz 10.01%. 


Speaker - The hybrid output is passed through a programmable attenuator and fed to 
this analog pin. Four different levels can be attained by controlling bit 0 and bit 1 of the 
SPKR register as specified under SPKR register description. 


Capacitor for Energy Detect - A 1.0 uF capacitor should be connected between this pin 
and AGND. 


Digital Ground 


Chip Select - An active low TIL input. 


Write - This TTL input is normally high. Data on ADO-AD7 is written into the VL7C224A 
registers at the rising edge of this pulse. 


Read - A normally high TTL input. Data on ADO-AD7 is read from the VL7C224A regis- 
ters at the rising edge of this pulse. 


Multiplexed Address/Data Bus (8-bits) - These four TTL I/O bits are used for multiplexed 
addressing and data I/O of internal registers. 


Negative Power Supply - -5 V 


Receive Analog - Input. 


Transmit Analog - Output. 


Data Bus Bits 0,5, 6, and 7 - They are don't cares as far as the address is concerned. 


Clock Input - 9.8304 MHz or 12.288 MHz clock input from the VL7C225/235/245, or 
external controller. 


Gain Select - To compensate for loss in line coupling transformer. When left open or tied 
to VSS, the compensation is 0 dB. Connected to ground, +2 dB compensation is pro- 
vided, and when tied to VDD, the compensation is +3 dB. 


Address Latch Enable - The address on A/D4-A/D1 is latched into the VL7C224A 
address decxader at the falling edge of a positive pulse on this normally low 'l'l'L input. 


Interrupt - A normally low TIL output. A short (13 ps typical) positive pulse is generated 
after all A to D conversions are completed. 


Received Data - A TTL output. 


Transmit Data - A TTL input. 


Positive Power Supply - +5 V 
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FUNCTIONAL DESCRIPTION 
- Full transmitter consisting of 
- Async to sync converter 
- Scrambler 
— Data encoder 
- 75% square root of raised cosine 
pulse shaper 


— Quadrature modulator 
- FSK (Bell 103 and CCITT V.21) 
modulator 
- Hybrid 


- High-band and low-band filters 


- High-band and low-band compromise 
equalizers 


- V.22 Notch filter (selectable at 550 or 
1800 Hz) 


- Transmit smoothing filter 


- Programmable attenuator for transmit 
level adjust 


- DTMF, 550 Hz, 1800 Hz, 1300 Hz, 
and 2100 Hz tone generators 


- Transmit clock circuit for synchronous 
operation (slave, external, and 
internal modes) 


- Pattern generator for generating fixed 
digital patterns in handshaking mode 


~ Receive section consisting of 


— 64-step programmable gain 
controller (PGC) 
- Energy detector at the output of 
the PCG 
- Hilbert transformer 


— Quadrature demodulator (free 
running carrier) with low pass 
filters 
- Baud timing recovery circuit 
(sampling clock of 600 Hz) 


— FSK demodulator 
- Sync to Async converter 
_ 


- 8-bit analog to digital converter (ADC) 


- Control and status register 


- 8-bit microprocessor interface with 
interrupt and multiplexed addressl 
data lines 


- Audio output with level adjust 


TRANSMITTER 
Since data terminals and computers 
may not have the timing accuracy 
required for 2400/1200 bps transmis- 


sion (0.01%), timing correction on the 
incoming data stream must be made. 
The async/sync convertor accepts 
asynchronous serial data clocked at a 
rate between 2400/1200 Hz + 2.3%, - 
2.5%. It outputs serial data at a fixed 
rate of 2400/1200 Hz :1: 0.01% derived 
from the master clock oscillator. To 
compensate for the input and output 
rate differences, a stop bit is either 
deleted or inserted when necessary. ll 
the input data rate is slower than the 
output rate, a stop bit is inserted. If the 
input data rate is faster than the output 
data rate, a stop bit is deleted. The 
output of the async/sync convertor is 
applied to the scrambler. 


The scrambler is a 17 bit shift register 
clocked at 2400/1200 Hz. Outputs from 
the 14th and 17th stages are exclusive 
OR'd and further exclusive OR'd with 
the input data. The resultant data is 
applied to the D input of the shift 
register. Outputs from the first four/two 
stages of the shift register form the 
quad/dibit that is applied to the QAMI 
QPSK modulator. The purpose of the 
scrambler is to randomize data so that 
the energy of the modulated carrier is 
spread over the band of interest - either 
the high-band centered at 2400 Hz or 
the low-band, centered at 1200 Hz. In 
the 2400 bps mode, the modem actually 
sends four bits at a time, called a 
quadbit; quadbits are sent at 600 baud, 
the actual rate of transmission; 600 
baud is the optimum rate that can be 
transmitted over the general switched 
telephone network for a full duplex FDM 
(frequency division multiplexing) 
modem because band limit filters in the 
central office cut off at about 3000 Hz. 


In the 2400 bps data rate, the data to be 
transmitted is divided into groups of four 
consecutive bits (quadbits). The first 
two bits of the quadbit is encoded as a 
phase quadrant change relative to the 
quadrant occupied by the preceding 
signal element. The last two bits define 
one of the four signaling elements 
associated with the new quadrant. 


In the 1200 bps data rate, the data 
stream is divided into groups of two 
consecutive bits (dibits), the dibits are 
used to determine the phase quadrant 
change relative to the quadrant 
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occupied by the preceding signal 
element. The resulting signaling 
elements from the inphase (I) and 
quadrature (O) channels are passed 
through base-band filters with a square 
root of raised-cosine shape. The 
filtered signals subsequently modulate 
sine and cosine carriers and add to 
form the OAM/OPSK signal. The wave 
shaped signal is then passed through ° 
either the low-band or high-band filter 
depending upon originate or answer 
mode selection. 


For low speed operation the FSK 
modulator is used. It produces one of 
four precision frequencies depending on 
originate or answer mode and the 1 
(mark) or 0 (space) level of the transmit 
data. Different frequencies are used for 
V.21 and 103 modes. The frequencies 
are produced from the master clock 
oscillator using programmable dividers. 
The dividers respond quickly to data 
changes, introducing negligible bit jitter 
while maintaining phase coherence. 
The output of the FSK modulator is 
applied to the appropriate filter when 
the low speed mode of the operation is 
selected. 


The filter section consists of low-band 
(1200 Hz) and high-band (2400 Hz) 
filters, half-channel compromise 
amplitude and group delay equalizers 
for both bands, smoothing filters for 
both bands and multiplexers for routing 
of the transmit and receive signals 
through the appropriate band filters. 
For CCITT V.22 bis applications, a 
notch filter is included that can be 
programmed for either 550 Hz or 1800 
Hz. In the call progress monitor mode, 
the low-band filter is scaled down by a 
factor of 2.5 to center it over afre- 
quency range of 300 to 660 Hz. Thus, 
during call establishment in the origi- 
nate mode, call progress tones can be 
monitored through the scaled low-band 
filter and the modem answer tone or 
voice can be monitored through the 
unscaled high-band filter. 


The low-band filter is a tenth order 
switched-capacitor band-pass filter with 
a center frequency of 1200 Hz. In the 
originate mode, this filter is used in the 
transmit direction; in the answer mode it 
is used in the receive direction. When 
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analog loopback is used in the originate 
mode, this filter, together with the low- 
band delay equalizer, is in the test loop. 
In the call progress monitoring mode, 
the filter response is scaled down by 
2.5, moving the center frequency to 480 
Hz. 


The low-band delay equalizer is _a tenth 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the low-band filter and half 
of the compromise line characteristics, 
producing a flat delay response within 
the pass-band. 


The high-band filter is a tenth order 
switched-capacitor band-pass filter with 
center frequency of 2400 Hz. In the 
answer mode, this filter is used in the 
transmit direction; in the originate mode, 
it is used in the receive direction. When 
analog loopback is used in the answer 
mode, this filter, together with the high- 
band delay equalizer, will be in the test 
loop. 


The high-band delay equalizer is a tenth 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the high-band filter and half 
of the compromise line characteristics, 
producing a flat delay response within 
the pass-band. The transmit smoothing 
filter is a second order low-pass 
switched-capacitor filter that adds the 
modem transmit signal to the DTMF or 
V.22 guard tones. It also provides a 2 
dB per step programmable gain function 
to set the output level. 


RECEIVER 
The receiver section consists of an 
energy detector, programmable gain 
control (PGC), part of the OAM/OPSK 
demodulator, FSK demodulator, 8 bit 
ADC and sync/async convertor. 


The received signal is routed through 
the appropriate band-pass filter and 
applied to the energy detector and PGC 
circuit. The energy detector provides a 
detection within 17 to 24 msec. It is set 
to turn on when the signal exceeds -43 
dBm and turn off when the signal falls 
below -48 dBm measured at the chip. A 
2 dB minimum hysteresis is provided 
between the turn on and turn off levels. 
In call progress mode the energy 
detector is connected to the output of 
PGC to allow detection level adjust- 
ment. 


The output of the filter is applied to the 
programmable gain control (PGC). This 
circuit has a wide overall range of 47.25 
dB and provides 64 steps of 0.75 dB/ 
step. The PGC gain is controlled by the 
external processor. lt also includes au- 
tozeroing to minimize the output DC 
offset voltage. 


The OAM/OPSK demodulator uses a 
coherent demodulation technique. 
Output of the programmable gain 
control (PGC) is applied to a hilbert 
transformer that produces an in-phase 
and 90° out of phase component. 
These components are then demodu- 
lated to base-band in a mixer stage 
where individual components are 
multiplied by a free running carrier. The 
base-band components are low-pass 
filtered to produce I and Q channel 
outputs. (In phase and quadrature.) 
The I and O channel outputs are both 
filtered by 300 Hz band-pass filters. 
Then they are rectified, summed and 
passed through a band-pass filter giving 
a 600 Hz signal. This signal is applied 
to a digital phase lock loop (DPLL) to 
produce a baud rate clock. Using the 
recovered clock signal, the I and Q 
channels are sampled and digitized into 
8-bit samples by the ADC. Each 
channel (I and O) is sampled twice 
during a baud period, once at the 
middle and once at the end of the baud 
period allowing T/2 or T sampling 
operation. The external processor is 
interrupted once every baud period 
(1.667 msec). The processor should 
read the I and O samples (within 100 
usec from the time interrupt is issued), 
and perform adaptive equalization, 
carrier phase tracking, datadecoding, 
and data descrambling. One quad/dibit 
is then transferred to the VL7C224A 
during each baud period. 


In the asynchronous mode, data 
received from the external processor is 
applied to the sync/async converter to 
reconstruct the originally transmitted 
asynchronous data. For data which had 
stop bits deleted at the transmitter 
(overspeed data), these stop bits are 
reinserted. Underspeed data is passed 
essentially unchanged. The sync/async 
convertor has two modes of operation. 
In the basic signaling mode the buffer 
can accept an overspeed which 
corresponds to one missing stop bit in 
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eight characters. The length of the start 
and data bits will be the same and the 
stop bit will be reduced by 12.5%. In 
the extended signalling range, the 
buffer can accept one missing stop bit 
in four characters and the stop bits will 
be reduced by 25% to allow for over- 
speed in the transmitting terminal. 
Output of the sync/async convertor 
along with the output of the FSK 
demodulator is applied to a multiplexer. 
The multiplexer selects the appropriate 
output, depending on the operating 
speed, and outputs received data on 
the RXD pin. 


For low speed operation, the FSK 
demodulator is used. the output of the 
PGC amplifier is passed through a zero 
crossing detector and applied to a 
counter that is reset on zero crossings. 
The counter is designed to cycle at a 
rate four times faster than the carrier 
signal. The counter output is low-pass 
filtered and hard limited to generate 
FSK data. 


To improve performance of receiver at 
low signal levels, while maintaining a 
wide amplitude range, a 1-bit AGC 
circuit is placed prior to band-pass filter. 
The decision thresholds of this AGC are 
controlled by AGCVT bit. When 
AGCVT = 1, the thresholds will be 6 dB 
farther apart than when AGCVT = 0, so 
that probability of gain change will be 
reduced. The status of the AGC gain is 
available through AGCO bit. AGC will 
have 8 dB more gain when AGCO =1. 
Status of AGCO should be monitored 
every baud timing and when it makes a 
transition (causing gain-hit). PGC’s 
gain should be modified by the external 
processor accordingly to prevent 
divergence of the adaptive equalization. 


HYBRID 
The signal on the phone line is the sum 
of the transmit and receive signals. The 
hybrid subtracts the transmitted signal 
from the signal on the line to form the 
received signal. It is important to match 
the hybrid impedance as closely as 
possible to the telephone line to 
produce only the received signal. When 
the internal hybrid is used, by setting 
the "HYBRlD” bit in the control register, 
this matching is provided by an external 
resistor connected between the TXA 
and RXA pins on the VL7C224A. The 
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filter section provides sufficient attenu- 
ation of the out of band signals to 
eliminate leftover transmit signals from 
the received signal. The hybrid also 
acts as a first order low-pass antiali- 
asing filter. The hybrid can be deacti- 
vated by the external controller. 


The VL7C224A internal hybrid is 
intended to simplify the phone line 
interface. The internal hybrid can 
compensate for the loss in the line 
coupling transformer used in the DAA. 
Depending upon the transformer 
selected, the loss can be as little as 1 
dB or as high as 3 dB. Internal hybrid 
can make up for this loss from 0 to 3 
dB, using the GS pin. 


With higher loss transformers, some 
degradation in performance at lower 
signal levels will occur. Specifically, the 
bit error rate, when operating at receive 
signal levels below -40 dBm in the 
presence of noise, will be higher. The 
energy detect on/off levels measured at 
the line will also be different from those 
specified at the chip. An external hybrid 
circuit, shown in Figure 2, can be used 
to overcome these losses and achieve 
maximum performance. In this case the 
internal hybrid must be turned off. 


The external hybrid circuit uses two 
operational amplifiers, one in the 
transmit path and the other in the 
receive path. The VL7C224A internal 
transmit stage provides a gain of 6 dB 
over the transmit signal level desired at 
the line. Under ideal conditions, with no 
loss in the transformer and perfect line 
matching, the signal level at the line will 
then be desired value. In practice, 
however, there is impedance mismatch 
and a loss in the coupling transformer. 
Therefore it may be desired to provide a 
gain in the transmit and receive paths to 
overcome the loss. The receive gain 
GR and transmit gain GT are set by the 
ratios of resistors R2, R1 and R6, R5_ 
respectively (Figure 2). 


The circuit can be analyzed as follows: 
vn . -(R2/R1) (VTR) + (1 + R2/R1) 
[R4/(R3 +R4)) VY 
VY . -(R6/R5) vx 


If R6/R5 is chosen to equal the loss in 
the transformer, it can assumed that VY 
is twice as high as VX (transmit portion 
of the total line signal). Since 
vta .-= vx + vnx and VY = 2 (vx), 


VR -= -(R2/R1) (VX -i- VRX) + (1 + R2/ 
R1) [R4/(R3 -i- R4)] 2 (VX) 


= -(R2/R1) vex + {(1 + R2/R1) 
[2R4/(R3 + R4)] -(R2/R1)} (vx) 


To eliminate any transmit signal from 
appearing at the received signal input, 
the second term in the above equation 
must be set to zero, giving: 


(1 + R2/R1) [2R4/(R3 + R4)] = R2/R1 


R3/R4 = 1 -1- (2R1/R2) 


Additionally, 


GR = R2/R1 and GT = R6/R5 


These equations can be solved to 
select component values that meet the 
desired requirements. For example, if 
the transmit and receive loss in the 
coupling transformer is 2.5 dB, then: 


R2/R1 - INV Log (GRdB/20) -= INV Log 
(2.5/20) = 1.333 


Similarly, 


R6/R5 = 1.333 and R3/R4 = 2.5 


Some typical values are: 


R1 -= 20k Q, R2 == 27k Q, R3 = 13k Q. 
R4 == S.1k Q, R5 = 20k Q and R6 = 27k 
Q. 


It should be noted that the transmit 
amplifier is only needed to overcome 
the loss in line coupling. It can be 
eliminated since the transmit signal 
level specification is typically stated as 
a maximum. Amplifier B, resistors R5 
and R6, and capacitor C1 can be 
eliminated and point VX connected to 
point VY in the circuit of Figure 2 to 
achieve a more cost effective external 
hybrid arrangement. 


The VL7C224A with the internal hybrid 
may also be used on a four-wire system 
where the transmit and receive signals 
are kept separate. In this mode, the 
Hybrid bit in TXCR must be turned off. 
The transmit signal is connected to a 
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600 Q line transformer through a 600 Q 
resistor. 


TONE GENERATOR 
The tone generator section consists of a 
DTMF generator, V.22 guard tone, 1300 
and 2100 Hz tone generator. The 
DTMF generator produces all of the 
tones corresponding to digits zero 
through 9 and A, B, C, D, ‘, and # keys. 
The V.22 guard tone generator pro- 
duces either 550 Hz or 1800 Hz tone. 
Selection of either tone will cascade the 
corresponding notch filter with the low- 
band filter. The tones are selected by 
applying appropriate codes through the 
Data I/O pin. Before atone can be 
generated, tone mode must be se- 
lected. Facility is also provided to 
generate single tones corresponding to 
1300 and 2100 Hz and the individual 
rows or columns of the DTMF signal. 


AUDIO OUTPUT STAGE 
A programmable attenuator that can 
drive a load impedance of 50k Q is 
provided to allow monitoring of the 
received line signal through an external 
speaker. The attenuator is connected 
to the output of the hybrid. Four levels 
of attenuation - no attenuation, 6 dB 
attenuation, 12 dB attenuation, and 
squelch are provided through the ALC1, 
ALCO audio output level control codes. 
Output of the attenuator is available on 
the audio output pin where an external 
audio amplifier (LM386 type) can be 
connected to drive a low impedance 
speaker. The output can directly drive a 
high impedance transducer, but the 
volume level will be low. 
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FIGURE 2. 
USING AN EXTERNAL HYBRID WITH THE VL7C224A. 
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FUNCTIONAL DESCRIPTION OF THE VL7C225, VL7C235, AND VL7C245 
The VL7C235 modem controller, 
implemented in VLSl's two-micron 
CMOS process, was designed specifi- 
cally to handle all of the modem control 
functions, as well as the interface to a 
system bus. Besides including a 16-bit 
microprocessor, 8K by 8 bytes of ROM 
and 304 by 8 bytes of RAM, it also 
contains the functionality of an 8250B 
UART, greatly simplifying the interface 
to a parallel system bus, such as the 
one used in IBM's PC. In fact, a 
complete Hayes-type compatible 
modem for the PC consists of the 
VL7C235 controller, the VL7C224A 
modem and the DAA. All of the popular 
communications software written for the 
PC will work with the VL7C224A/ 
VL7C225 set. 


Another version of the controller, the 
VL7C245, is intended for RS-232 
applications. It contains the same 
processor, memory and UART as the 
VL7C224A and has the same interface 
to the modem chip. The difference is 
that the UART is turned around so that 
serial data from the RS-232 port is 
converted to parallel data handled by 
the internal processor. Pins are 
provided for connecting the familiar 
switches and indicator lamps found on 
most stand-alone modems, although 
the switches and lamps are not needed 
for operation - all of the switch settings 
can be done through software. A third 
version, the VL7C225 uses external 
EPROM memory instead of internal 
ROM for full customization to specific 
applications. The internal UART can be 
software configured (for either parallel 
bus or serial RS-232 data applications. 


The controller receives 8-bit signal 
sample from VL7C224A and performs 
adaptive equalization, carrier phase 
recovery, data decode, and descram- 
bling. VL7C225, VL7C235, and 
VL7C245 have identical hardware. 
Each controller can be configured as a 
VL7C235 or VL7C245 by the software. 
The controller is designed by using a 16 
bit 2900 processor to perform the digital 
signal processing and the control 
functions. Its instruction set is a subset 
of the Intel 8096 instruction set but 
operates faster than the 8096. 


The VL7C245 provides a standard five 
volt logic level interface. RS-232 
drivers are required to interface to the 
serial port. Like the VL7C235, the 
VL7C245 comes preprogrammed with 
the Hayes “AT” command set, and 
when used with the VL7C224A modem, 
emulates a Hayes-type stand-alone 
modem. The VL7C235 and VL7C224A 
emulate a Hayes-type IBM PC plug-in 
card modem. 


But the chip set is by no means limited 
to implementing a Hayes-type smart 
modem. VLSI is in the custom IC 
business and both chips were designed 
with this in mind. And since the 
controller is ROM programmable, any 
command set, not just the Hayes "AT" 
set, can be implemented. 


Both the VL7C235 and VL7C245 are 
available in two different pinout options. 
They are 44-pin and 40-pin. 
The 
VL7C225 is available in a 68-pin 
package. (The 68-pin package allows 
the controller to access external ROM 
for up to 32K bytes and external RAM 
for up to 16K bytes. This allow users to 
customize their own software. And 
provides a mean for software develop- 
ment.) The 44-pin and 40-pin packaged 
VL7C235 and VL7C245 do not provide 
external ROM access. All three pinouts 
allow the controller to talk to both the 
VL7C224A and a SC22102-1 
(EEPROM). 


The interface to the VL7C224A is via an 
8-bit address/data bus and the control 
lines for read and write. The same 
interface is used for access to an 
electrical erasable random access 
memory (SC22102-1). They operate on 
six clock multiplexed address/data bus 
cycles. For the 44-pin option an I/O 
ready signal is provided for interface to 
high speed PC/AT type bus cycle. For 
the VL7C225 there are 15 extra 
address lines and chip selects for 
external ROM and extrnal RAM 
interfaces. 


Besides the interface for the VL7C224A 
modem, the VL7C235 controller has an 
8-bit data port, three address lines, a 
chip select input, an interrupt line, and 
the DOST and DIST control lines found 
in the 8250B UART. It also has control 
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lines for ring indication, the off-hook 
relay and a data/voice relay; these lines 
connect to the DAA. 


In the VL7C245, the 8-bit port becomes 
the switch input lines and the address, 
chip select, INTO, DIST, and DOST 
lines become the lines for the RS-232 
interface, and modem status. These 
lines are also used to drive the LEDs. 
Internally, all of these lines are treated 
as programmable I/O ports under 
software control - so the main difference 
between the VL7C235 and VL7C245 is 
the ROM code. It also contains the 
same modem and DAA interface lines 
as the VL7C225A. 


The VL7C235 and VL7C245 are 
designed to control a modem or other 
peripheral that operates at a moderately 
slow data rate up to 2400 bits per 
second. The VL7C235 allows a slow 
peripheral, such as the modem, to 
interface to a high speed bus, without 
making the main processor slow down. 


This is done through the UART inter- 
face and the on-chip registers which 
look somewhat like dual port registers. 
The main processor can write to and 
read from them at will, while the on-chip 
controller can do the same. The 
controller was designed this way 
because most communications software 
has to have unrestrained access to the 
UART registers. To make the VL7C235 
compatible with this software, these 
registers were included. 


The actual processor contains a 16-bit 
data path and can execute 54 instruc- 
tions with three different addressing 
modes: direct, indirect, immediate. 
There is 8K by 8 of ROM on-chip for 
program storage. 


To the system bus, the VL7C235 looks 
and acts just like an 8250B UART. 
Communications software written for 
the UART will work with the VL7C235 
and VL7C245. The VLSI chip set is a 
completely compatible Hayes-type 
modem in two chips. 


In operation, the VL7C235 or VL7C245 
monitor the registers to determine the 
mode of operation - command mode or 
data mode; at power-up it is automati- 
cally put in the command mode and it 
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looks for instructions. Once carrier is 
sequence is entered, just like in a 
default mode, but it can be changed in 
detected, it goes into the data mode, 
Hayes-type modem. The escape 
software. 
and stays there until an escape 
sequence is three + signs (+++) in the 


REGISTERS 
Ther 
to the microprocessor bus. Five of 
these registers can only be read by the 


e are 12 8-bit reigsters interfacing 
READ REGISTERS 


Q1 Register: 
Stores Midbaud Quadrature Sample Output of ADC 


processor (called READ registers) and 
I1 Register: 
Stores Midbaud lnphase Sample Output of ADC 
the remaining seven can be read from 
_ 
_ 
or written into by the processor (caued 
Q2 Register. 
Stores Endbaud Quadrature Sample Output of ADC 


CONTROL 'e9ISI°_'s)' Table I shows 
I2 Register: 
Stores Endbaud lnphase Sample Output of ADC 
the address and bit assignments for 
these registers. 
Status Register: 
Status information 


A CIIIP Self‘-‘Cl Pl" I5 PTO)/lded l°Y "'\U|ll' 
Note: All samples are represented in two's complement form. 
peripheral addressing by the processor. 


TABLE 1. READ REGISTERS 


A 
M EEE—iBIKZ-_ 
° lIEII1§E- 
Iluiilllll 
0 


0 


0 


0 


0 


0 


LSB 


O 


Q10 


I10 


Q20 


I20 


ED 


ddress Blts 
@ MSB 
Blt Number 


EIIIIKWEIEEEI 
Elllliilli 
Elli 
II!—----- 
IIIII:----— 


TABLE 2. STATUS REGISTER ADDRESS (A4-A1) = 0100 


Blt Number 
Blt Name 


Bit 7 


Bit 4 


Bit 3 


Bit 2 


Bit 1 


Bit 0 


Note 


Descrlptlon 


Note 2 


‘U 


-5 
Unused 


When this bit is set, RXA signal is being amplified by 8 dB before entering the band-pass 
AGCO 
filters by the AGC circuit. 


This bit is set whenever the DPLL advances one step (skips a count) to lock. It is 
cleared only when STATUS register is read. 


This bit is set whenever the clock recovery DPLL retards one step (adds a count) 
to lock. It is cleared only when STATUS register is read. 


FSKD 
Received FSK data. FSKD - 1 when a mark is received. 


Energy detect circuit output. ED = 1 when energy is detected. 


s: 1. When DPLL neither advances nor retards, then PA -= PR -= 0. 
2. When reading unused bits, the corresponding bus lines will not be driven by the VL7C224A and will be floaing. 
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TABLE 3. CONTROL REGISTERS 


Address Blts 
M mm 


1 IIIIII 


-at 
I 
H 


2 
(D 
@ 


@ 
tx R 
HYBRID 
TXSEL2 


1 EEK SYN° 


1 EEK A B 
T12 
“-1 


1 EIIIIWE 


1 IIEE 


1 IIEII@IiI 


1 
DISS 
PGCZ 
tst2 
TST1 
tsto 
ALC1 


1 IIIIII— 


Bit Number 


BRO 


RXMRK 


TLO 


D0 


G0 


RDO 


ALC2 


TXSEL1 
TXSELO 


WLS1 
H 


TABLE 4. 
TRANSMIT CONTROL REGISTER (TXCR): ADDRESS (A4-A1) = 1000 
Blt Number 
Blt Name 


Bit 7 


Bit 6 


Bit 5 


Bit 4 


Bit 3 


Bit 2 


Bit 1 


Bit 0 


Unused 


HYBRID 


TXSEL2 


TXSEL1 


TXSELO 


SQT 


Descrlptlon 


When set, the transmitter output (TXA) is connected to the inverting input of the receive 
buffer to allow the use of the on-chip hybrid circuit for 2-to-4 wire conversion 


Transmit Select bit 2. Determines the data transmitted by the transmitter according to 
Table 5. 


Transmit Select bit 1. Determines the data transmitted by the transmitter according to 
Table 5. 


Transmit Select bit 0. Determines the data transmitted by the transmitter according to 
Table 5. 
When this bit is set, the transmitter is squelched by connecting the output of MUX1 
(see block diagram) to analog ground. 


Bit Rate Selection bit1. See Table 6. 


Bit Rate Selection bit 0 
See Table 6 
BRO 
. 
. 


Note: When writing into these registers, the bus lines corresponding to the unused bits are ignored by the VL7C224A. 
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TABLE 5. TRANSMIT SELECTION BITS 


TXSEL1 
TXSELO 
TXSEL2 


0 


0 


0 


0 


1 


1 


1 


1 


Notes: 1. S1 is a pattern of 0011 transmitted at 1200 bps rate regardless of BR1. If in FSK mode (BRO -= 1), then reversals 


2 


3 
4 


TABL 


Transmitted Data 


External data sent by DTE. 


Unscrambled S1 (Note 1). 


Unscrambled Space. 


Unscrambled Mark. 


Scramb'ed RX. Digital loopback mode (Note 2). 


Scrambled Reversals (Notes 3 and 4). 


Scramb'ed Space (Note 4). 


Scrambl ed Mark (Note 4). 


are sent. This pattern cannot be sent at 2400 bps rate. 


. In this mode the received data, after being descrambled, is sent back to the scrambler. The modem will automatically 
go to the synchronous mode with slave timing. 


-*@-‘Q 


ITI 


-L-AQ 


. Reversals are continuous streams of 01. 


. When in FSK mode (BRO = 1), TXSEL2 is ignored since scrambling is not applicable. 


BIT RATE SELECTION BITS 


BR1 
BRO 
Blt Rate 


2400 bps V.22 bis 


1200 bps V.22/212A 


0-300 bps Bell 103 


0-300 bps CCITT V.21 


TABLE 7. MODE CONTROL REGISTER A (MCRA): ADDRESS (A4-A1) = 1001 


Blt Number 
Descrlptlon 


Bit 7 


Bit 6 


Bit 5 


Bit 4 


Bit 3 


Bit 2 


Bit 1 


Bit 0 


LCK/-INT 


RNGX 


SYNC 


WLS1 


WLSO 


A/-O 


RXMARK 


Determines the clock source for the transmitter. When this bit is set clock source is 
externally provided on SCTE (pin 4), and when cleared it is internally generated (SCT). 
This bit can select the clock source independent of sync/async mode selection (see 
below). When in digital loopback mode, the clock source will be forced to the slave 
mode. 


Range extender for the receiver sync/asnyc converter. When set, the receiver syncl 
async can insert up to one stop bit per four (8, 9, 10, or 11-bit) characters to compen- 
sate for a far end DTE being up to 2.3% overspeed. The transmitter async/sync always 
handles this overspeed condition regardless of this bit's condition. 


When set, operate in bit synchronous mode; when clear, operate in character asyn- 
chronous mode. When in digital loopback mode, the VL7C224A will be forced to the 
synchronous mode. 


Word Length Select bit in asynchronous mode, see Table 8. 


Word Length Select bit in asynchronous mode, see Table 8. 


When set, operate in answer mode. When clear, operate in originate mode. 


When set, the RXD pin is clamped to the high logical level. 
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I'I1 F’ 
TABL 
WORD LENGTH SELECTION BITS 


WLS1 
WLSO 
Number of Bits Per Character 


oo-- 


TABLE 9. MODE CONTROL REGISTER B (MCRB): ADDRESS (A4-A1) = 1010 


Blt Number 
Blt Name 
Descrlptlon 


Bit 7, 6 


Bit 5 


Bit 4 


Bit 3 


Bit 2 


Bit 1 


Bit 0 


CLKSEL 
This bit must be set when CLKIN =- 12.288 MHz, and clear when CLKIN -= 9.8304 MHz. 


Call progress monitor mode. When set, the receive path can be connected to the 
CPM 
high-band filter to detect answer tone (ALB = 0) or to the low-band filter scaled down 
2.5 times (ALB = 1) to listen for the call progress tones during auto dialing 


ALB 
Auto loopback mode. When set and CMP = 0, the transmitter output (TXA) is 


F‘ 
I_I-O 
—* 
ID 


connected to the receive path, bypassing the receive filter. 


Transmit level adjust bit based on Table 10. 


Transmit level adjust bit based on Table 10. 


Transmit level adjust bit based on Table 10. 


TABLE 10. TRANSMIT LEVEL SELECTION BITS 


TL2 


0 


0 


0 


0 


1 


1 


1 


1 


ii 
1- 
—K 
———— 
I——I 


Transmit Level at TXA Pln 


0dBm 


-2 dBm 


-4 dBm 


-6 dBm 


-8 dBm 


-10 dBm 


-12 dBm 


-14 dBm 
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TABLE 11. TONE REGISTER: ADDRESS (A4-A1)=1011 


Blt Number 
Blt Name 
Descrlptlon 


Bit 7 
Unused 


VL7C224A 


This bit is set only during handshaking sequence. When set, both FSK and PSK/QAM 
Bil 5 
HNDSHK 
demodulators are enabled. When cleared, the FSK demodulator is disabled when in 
high speed mode. 


Bit 5 
TONEQN 
When set, the output of the tone generator appears at TXA. When cleared, the 
output of the tone generator is squelched. 


Bit 4 
DTMF 
When set and TONEON = 1,the DTMF generator is turned on. When cleared, the DTMF 
generator is turned off but other tones can be generated. 


Bit 3-0 
D3-D0 
Specify the desired tone (see Table 12). 


TABLE 12. TONE GENERATION DATA BITS 


DTMF 
Dlglt Dlaled 
Tone Output Frequencies (Hz) 


1 


1 


Q@QQQ()QQ_;_;-L.-.A_.;-A-4_;_;_|._L_.A...A...A 


() 
() 
() 


( 
) 


941/1336 


697/1209 


697/1336 


697/1477 


770/1209 


770/1336 


770/1477 


852/1477 


852/1477 


852/1477 


941/1477 


697/1477 


770/1477 


852/1477 


941/1477 


941/1477 


No Tone; Tone Generator Turned Off 


550 


1800 


2100 


1300 


No Tone; Tone Generator Turned Off 


No Tone; Tone Generator Turned Off 


No Tone; Tone Generator Turned Off 
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TABLE 13. PROGRAMMABLE GAIN CONTROL REGISTER (PGCR):AooRess (A4-A1) = 1100 


Blt Number 
Descrlptlon 


B" 1 
When set, prevents gain hit due to AGC's gain step. This bit must be set during 
BI‘ 5 
AGCVT 
the handshaking after detecting the four point constellation and before switching 
to 16 way decision making. 


Bit 5-0 
G5-G0 
Control the gain of the PGC (see Table 14.) 


TABLE 14. PROGRAMMABLE GAIN CONTROL BITS 
cs 
PGC Galn (us) 


° IIIIIIIIII 
-6 
° ulna‘. 
-5-25 
0 
-4.5 


0 u 
-3 


° H 
° 
° II“ 
+6 


1 
+1s 


1 _ 
+41.2s 


Note: Signal level is adjusted (before entering the filter) by the internal AGC with +8 dB or 0 dB gain. 


TABLE 15. DATA REGISTER: ADDRESS (A4-A1) = 1101 


Blt Number 
Descrlptlon 


_ 
When set, the DPLL will be reset by the next rising edge of the received baud clock. 
B" 6 
PI-I-JAM 
It must remain high for at least one baud period. It should be cleared by the processor 
to end the jamming mode. PLLFRZ overrides PLLJAM when both are enabled. 


Phase locked loop freeze. When set, the DPLL begins to run freely regardless of the 
Bit 5 
PLLFRZ 
received baud clock. To re-enable the DPLL locking, the bit must be cleared by the 
processor. PLLFRZ overrides PLLJAM when both are enabled. 


When set, the DPLL operates in a "fast" locking mode. In this mode, the DPLL is 
updated every baud period in13us steps. When clear, the DPLL operates in “normal” 
mode and is updated once every eight baud periods in 6.5 us steps. 


Bit 4 
PLLFAST 


Bit 3-0 
RD3-RDO 
4-bit Received Data. Used only in high speed (1200 or 2400 bps) mode, they are 
descrambled by the processor and shifted out by the VL7C224A. Sync to async is 
also done by the VL7C224A, when in the asynchronous mode. RDO is the first bit 
appearing on the RXD pin, followed by RD1, RD2, and RD3. In the 1200 bps mode, 
only RDO and RD1 are shifted out during one baud period. 
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TABLE 16. AUDIO REGISTER: ADDRESS (A4-A1): 1110 


Bit Number 
Bit Name 


Bit7 
Unused 


Descpon 


VL7C224A 


Bit 6 
DISS 
When this bit is set scrambler is disabled, when cleared it is enabled. Transmit select 
bits (TXSELO-2) override this bit when in "transmit internal mode”. 


Bi 5 
PGCZ 
When set, the output of the PGC is grounded. DC offset of the demodulator can be 
I 
stored and cancelled by the controller. 


Bit 4-2 
TEST 
Test bits used for factory testing. For normal chip operation these bits must be cleared. 


Bit 1 
ALC1 
Audio level control bit 1. Used to control audio level at SPKR pin, see Table 17. 


Bit 0 
ALCO 
Audio level control bit 0. Used to control audio level at SPKR pin, see Table 17. 


TABLE 17. AUDIO LEVEL SELECTION BITS 


ALC1 
ALC1 
Audio Attenuation (dB) 


Audio Off 


---oo 


1L 


mm 


0 (No Attenuation) 


Note: The audio signal may be amplified by +8 dB by the AGC circuit. 
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AC CHARACTERISTICS 


Symbol 
Parameter 
T 


tAVLL 
Address Valid to end of ALE 


tLLAX 
Address Hold after end of ALE 


Address Valid to Output Data 
tAVDV 
Valid 


-RD Active Low to Output Data 


1*’1><°Z 
—“ 
1”“ 
-5 
"W1 
iii! 
“NLW11 
— 
1°"‘”>< 
m 
twxox 
Data Hold after end of -WR 


tLLRL 
End of ALE to -RD or -WR Active 


tRHLH 
End of -RD to next ALE 


IWXLH 
End of -WR to next ALE 


-L 


'5 


OJ O7 


tXL 
Transmit Level Measured at TXA 


Note: Processor Bus Interface: see Figure 3. 


FIGURE 3. BUS TIMING WAVEFORMS 


ILHLL 


ALE 


ILLRL 
IRHLH 
IRLRH 


READ 
ILL/ix 
tAVLL 
IRLDV 
IRXDZ 


DATA OUT 
I. 
ADDRESS IN 


tAVDV 


ILLRL 
twLw|-| 
tWXLH 


__WR 
- 


WRITE 
IQVWX 
IWXQX 


A/D 
ADDRESS IN 
DATA IN 
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Condltlon 


Load == 1200 Q 


TL2=TL1=TLO=0 
Squelched 


S 


SYNCHRONOUS OPERATION 
Transmitter Timing 
Case 1 - VL7C224A provides the timing 
to the Data Terminal Equipment (DTE). 
See Figure 4. 


If the DTE can lock to an external clock, 
then all that needs to be done is to put 
the VL7C224A in the synchronous 
mode. This provides a 1200 Hz clock 
on the SCT pin that can be used as a 
clock source for the DTE to synchronize 
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its TXD to. The DTE must then 
synchronize its TXD to a 1200 Hz clock 
provided on the SCT pin. The transmit 
phase locked loop (TXPLL) of the 
VL7C224A will be in free running mode. 


Case 2 - VL7C224A should lock its 
transmit timing to the clock source 
provided by the DTE. 


In this case, after selecting synchronous 
mode, also select "locked" mode via the 


FIGURE 4. SYNCHRONOUS MODE CLOCK ALIGNMENT 


TRANSMITTER 


SCTE INPUT 
TX CLOCK 


TXD 
INPUT DATA 


SCT TXPLL 
OUTPUT CLOCK 


SCR 


RECEIVER 
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LCK bit of the MCRA register.. 


The VL7C224A will then synchronize 
itself to the clock provided on its SCTE 
pin. 


Receiver Timing 
In synchronous mode, the recovered 
clock will be provided on the SCR pin 
and the transitions of RXD will be on the 
falling edges of this clock as shown in 
Figure 4. 
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MODEM TRANSMIT SIGNALS: ASSUME 9.3304 MHz CRYSTAL 


FSK MODULATOR/DEMODULATOR FREQUENCIES: BELL 103 


11"SW:'Ma"< 
W 
2226 
Answer Space 
2025 
2024.4 


011911“: Mat 
121° W 
Originate Space 
1070 
1070.4 


FSK MODULATOR/DEMODULATOR FREQUENCIES: CCITT V.21 


Parameter 
Condltlon 


A1818: Mark 
-5 
Atsweispas 
11 
<>'1@1"a1@Ma'1~ 
II 
011911111: Spas: 
iii 


CALL PROGRESS MONITOR MODE 


Parameter 
Condltlon 


Center Frequency 
ALB = 1 


Detect Level (ED High) Measured at RXA 


Reject Level (eo Low) Measured at RXA 


11Y$1e'1:1=~= 
m 
Delay Time (eo Low to High) 
eoc = 1.0 ILF 


Hold Time (eo High to Low) 
eoc = 1.0 tti= 


DTMF GENERATOR 
Parameter 
Nominal Frequency 
Allowable Error 
Actual Error 


Row 1 


Row 2 


Row 3 


Row 4 


Column 1 


Column 2 


Column 3 


Guard Tones 


Calling Tone 


Answer Tone 
W 
— 
— 
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-0.23% 


-0.01% 


-0.12% 


-0.39% 


-0.35% 


-0.93% 
- 


--0.48% 


-2 Hz 


-2 Hz 


-6 Hz 


-12 Hz 


® VLSI TECHNOLOGY, mc. 


MODEM TRANSMIT SIGNALS: ASSUME 9.22304 MHz CRYSTAL (Cont.) 


DTMF GENERATOR 
Parameter 
-I 


Second Harmonic Distortion 


Row Output level 


Column Output Level 


550 Hz Guard Tone 
-3 
dB (Note) 


1800 Hz Guard Tone 
-6 
dB (Note) 


1300 Hz Calling Tone 


2100 Hz Answer Tone 


VL7C224A 


Condltlon 


VCC = +5 V 


VSS =-5 V 


TL2 = TL1= TLO = 0 


Measured at TXA Pin, 
12009 Load 


Note: These levels are referenced to the TX signal level. When guard tones are added, the TXA level is automatically 
adjusted to maintain a constant level on the line. For 1800 Hz, the adjustment is -0.97 dB; for 550 Hz, the 
adjustment is -1.76 dB, per the CCITT specification. 


Data Mode (Note) 


Parameter 


Energy Detect Level (ED Low to High) 


Loss of Energy Detect Level 
(ED Low to High) 


Hysterisis 


Programmable Galn Controller (PGC) 


Ga‘"$*°PS‘1° 
-E 
°Y"a""<=F*a"g° 
“Q 
Response Time (from Change ln PGC 
Register to Output of A to D Converter 


Fllter Characterlstlcs 


¢'°SS*a'kReIe<=“<=~ 
ii 
P°we'S~PP'YRe1@°**°~ 
—IIE— 
DPLL Response times JAM or FRZ 


DPLL Response times Fast 


Note: EDC = 1.0 |.1F; measured at RXA. PGC = 0. 
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ABSOLUTE MAXIMUM RATINGS 


Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. 
Temperature 
0°C to +70°C 
permanent damage to the device. 
Exposure to absolute maximum rating 
Storage Temperature _65<,C to +1 50°C 
Theseiare stress ratings only, functional 
conditions for extended periods may 
operation of this device at these or any 
affect device reliability. 
Positive Supply Voltage 
other wnditions above those indicated 
to Ground Potential 
+6 V 


Negative Supply Voltage 
to Ground Potential 
-6 V 


Applied Input 
Voltage 
VSS -0.6 V to VCC +0.6 V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = o<=c to +1o<=c, vcc 5 v ¢1o%, vss 


Parameter 
Symbol 


ICC 


ISS 


VIH 


VIL 


VOH 


VOH 


VXTA 


EE 
°°"<""<=" 
I 


Digital Pins 
E11 


Digital Pins 
111 
1—- 
——i 
Maximum Peak Output Level 
i 3 
V 
on TXA Pin 


IOH = 0.5 mA 


lOL - 1.6 mA 


VCC=+5V 
VSS=-5V 


CLOCK CHARACTERISTICS 
Symbol 


FC 


TR, TF 


TR, TF 


Condition 


CLKSEL = 0 


CLKSEL = 1 


All Digital Inputs 
except CLKIN 
E 


. 
. 
. 
Z 


CLKIN 
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APPLICATIONS INFORMATION 


WHY A MODEM/WHAT'S A MODEM 
The voice frequency channels of the 
general switched telephone network 
have been used extensively for the 
transmission of digital data. To use 
these channels, the data must be put in 
a form that can be sent over a limited 
bandwidth line. In voice grade tele- 
_ 
phone networks, transformers, carrier 
systems and loaded lines attenuate all 
signals below 300 Hz and above 3400 
Hz. 


While the bandwidth from 300 Hz to 
3400 Hz is fine for voice transmission, it 
is not suitable for the transmission of 
digital data because the data has many 
frequency components outside this 
range. To transmit data over phone 
lines, it is necessary to convert the 
digital data into a signal that is totally 
within the voice frequency range. This 
conversion is performed by a MODEM 
(MODulator DEModulator). 


ln full duplex data transmission - the 
simultaneous sending and receiving of 
data - Frequency Division Multiplexing 
(FDM) can be used for data rates up to 
2400 bits per second. In FDM, the 
voice channel is divided into upper and 
lower bands (called the high-band and 
the low-band); one is used for sending 
and the other for receiving data. The 
originating terminal transmits in the low- 
band and receives in the high-band, 
while the answering terminal transmits 
in the high-band and receives in the 
low-band. 


In low speed modems (300 bit per 
second transmission rate), the modula- 
tion technique commonly employed is 
called Frequency Shift Keying (FSK). 
ln 
FSK modems, four separate frequen- 
cies are used; 1070 Hz for a zero (also 
called a space) in the low-band, 1270 
Hz for a one (a mark) in the low-band, 
2025 Hz for a zero in the high-band and 
2225 Hz for a one in the high-band. 
The transmitting modem takes the 
digital ones and zeros from the terminal 
and converts them into the proper tones 
which are then sent over the phone line. 
The receiving modem takes the tones 
and converts them back to ones and 
zeros and sends them to the receiving 
terminal. Since four frequencies are 


used, simultaneous transmitting and 
receiving of data can be accomplished. 


Because of limited bandwidth of the 
phone line, FSK modems only work up 
to 600 bits per second for full duplex 
transmission. This is due to the fact 
that when the modem shifts between 
the two frequencies (for mark and 
space) it generates a spectrum of 
frequencies (it is a type of FM - fre- 
quency modulation - transmission). The 
faster the data rate, the wider the 
spectrum. The limit for full duplex FSK 
transmission is 600 bits per second, 
before the available audio spectrum is 
used up and allowing for enough 
separation between the frequency 
bands to reliably decode or demodulate 
the data. There are 1200 BPS FSK 
modems, but these are half duplex, they 
can send or receive data at 1200 bps, 
but not simultaneously. 


ln high speed, full duplex modems 
(1200/2400 bit per second transmission 
rate) a different modulation technique is 
employed. Called PSK (for Phase Shift 
Keying), this technique uses one carrier 
frequency for the high-band, 2400 Hz, 
and one forthe low-band, 1200 Hz, for 
sending and receiving data. For each 
carrier frequency (one for transmitting 
and one for receiving), one of 16 phase 
and amplitude signalling levels is used. 
The data is sent four bits at a time,'or in 
quadbits. Since there are 16 ways to 
send four bits at a time, each of the 16 
signalling elements represents one 
unique quadbit. While the data rate is 
2400 bits per second, the baud rate (the 
rate at which information packets are 
sent) is 600 because four bits are sent 
in each packet. Again, 600 packets per 
second (600 baud and, in this case, 
2400 bps) is the limit for transmitting full 
duplex data over the general switched 
telephone network using FDM. 


V.22 bis is a CCITT specification that 
specifies 2400 bit per second, full or 
half duplex data transmission. V.22 bis 
specifies a fallback mode of 1200 bps 
which is defined by the V.22 specifica- 
tion. Neither V.22 bis nor V.22 call for a 
300 bps fallback; however, there is a 
CCITT standard for 300, V.21 and this 
mode is also provided by the chip set. 
ln addition the chip set provides for Bell 
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212A capability for the U.S. 1200 bps 
and 300 bps modes of operation. 


V.22 and V.22 bis also call for guard 
tones to be sent along with the data. ln 
most of Europe the tone is 1800 Hz 
except in Sweden where 550 Hz is 
used. The VL7C224A has the 500 Hz 
and 1800 Hz tone generators built in, as 
well as the 550 and 1800 Hz notch 
filters to remove the guard tone when in 
the receive mode. 


Power Supply Decoupling and Clrcult 
Layout Conslderatlon 
For optimum performance and to obtain 
the best possible performance at low 
received signal levels with low s/n ratio, 
it is important to use the recommended 
power supply decoupling circuit as 
shown in Figure 5. 


Small inductors in series with the 
positive and negative supplies help 
suppress RFI as well as improve the 
power supply noise rejection capability 
of the VL7C224A when used with the 
decoupling capacitors. The 10 pF 
capacitors should be tantalum type 
while the 0.1 uF capacitors should have 
a good high frequency rejection 
characteristic, monolithic ceramic types 
are recommended. 


lt is important to locate the decoupling 
capacitors as close to the actual power 
supply pins of the VL7C224A as 
possible. lt is also recommended that 
the analog ground and digital ground 
buses be routed separately and 
connected at the common ground point 
of the power supply. 


VL7C224A and DAA 
As shown in Figure 5 the only external 
components required by the VL7C224A, 
U1, for its operation are the 600 Q line 
matching resistor and a 1.0 pF capaci- 
tor from the EDC pin to ground. lf it is 
desired to drive a speaker to monitor 
the line, an external amplifier can be 
added, but the output provided on the 
VL7C224A can directly drive a high 
impedance (50 kQ) earphone-type 
transducer. ln Figure_5, U15 provides 
this amplifier. R12 will provide control 
of the maximum output level to the 
speaker. Note that the VL7C224A has 
an internal attenuator which allows 
software control of the audio level also. 
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All modems require a DAA. A DAA 
(data access arrangement) is a piece of 
equipment required by the FCC to 
connect anything to the general 
switched telephone network. In Figure 
5, it consists of an isolation transformer, 
typically 600 Q to 600 Q (T1); a relay for 
disconnecting the modem from the line 
(K1); a ring detector, typically an opto - 
isolator (U15); and high voltage surge 
protectors (VS1). Relay K1 also 
provides a means to pulse dial if that 
mode is desired. Tone dialling capability 
is provided internally in the VL7C224A. 
Also required is a hybrid function which 
separates the transmit and receive 
signals from the combined signal on the 
two wire telephone line. This function is 
provided internally to the VL7C224A 
although an external hybrid may be 
constructed (refer to previous section of 
this data sheet for more information). 
Diodes CR5 to CR8 provide a clamp to 
limit the maximum signal applied to the 
VL7C224A. The other relay in Figure 5, 
K2, and its related circuitry is normally 
used to control a telephone set con- 
nected to the modem. This circuitry is 
optional. The DAA must be FCC 
registered and this can be done by any 
of many consultants and labs around 
the country. Another alternative is to 
buy a certified DAA, supplied by several 
manufacturers. 


Two jumper selected options are shown 
in Figure 5. J1 is connected if an 
external synchronous transmit clock 
source is to be used. J2 has three 
positions and controls the receiver gain 
of the 7C244A to compensate for any 
transformer losses in T1: unconnected, 
no gain adjustment; to + 5 V, gain will 
be increased by + 3 dB; if tied to 
ground, gain will be increased + 2 dB. 


Also shown in Figure 5 is an optional 
128 byte EEPROM, U13, which can be 
used by the modem controller for 


storing configuration data and tele- 
phone numbers when the modem is 
turned off. 


CONTROLLER OPTIONS 
The VL7C224A is usually used with 
some form of controller. The controller 
does the tasks of programming the 
various modes of the VL7C224A and 
provides the equalization and PSKI 
QAM detection as well as controlling 
the handshaking sequences required 
for connection establishment. Usually a 
command language is used to commu- 
nicate with the modem controller from 
external systems and this must be 
included in the controller functions also. 
A well established standard for this 
command language is the ‘AT’ com- 
mand set used by Hayes in their 
modem products. 


Three controllers are available which 
provide all these capabilities as well as 
providing a built - in UART function: the 
VL7C225, VL7C235, and VL7C245 
Modem Advanced Coprocessors. The 
VL7C225 is the core device of this 
family and utilizes external EPROM or 
ROM for its program memory. It is also 
capable of using external RAM for 
temporary data storage. The VL7C225 
is capable of being used either in stand- 
alone serial modem applications or in 
bus - oriented applications, such as the 
IBM PC. The pin functions of the 
device may be reconfigured by the 
firmware to either application. Figure 6 
shows the VL7C225, U2, in a circuit 
which is applicable to either application. 
U3 provides the external program 
memory. A parallel resonant crystal, Y1 
is used by the VL7C225 to generate its’ 
clocks. The specifications of this crystal 
are very important: 19,6608 MHz i 
.001%, parallel resonant with an 18 pF 
load capacitance (Saronix NP196-18 ). 
Also shown in Figure 6 is an optional 
bus buffer for the ADO-AD7 bus, U5. 
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While not required for proper operation, 
this buffer improves the signal to noise 
performance of the modem. A future 
version of the VL7C224A is planned 
which will incorporate this buffer, at 
which time U5 may be omitted or 
bridged. Since the VL7C225 may be 
used for either serial or bus applica- 
tions, designations for the signals may 
have dual names. 


If a serial stand-alone modem is 
desired, Figures 5 and 6 may be 
combined with Figures 7 and 8 to form 
a complete modem. Figure 7 illustrates 
the circuitry required for the RS-282 
interface. indicator LEDs, and optional 
configuration switches which may be 
read by the controller at power - up to 
set configuration defaults. Figure 8 
provides a power supply circuit for 
converting the output of a 12 volt ac 
wall transformer into the voltages 
required by the rest of the circuitry. 


Figure 7 may be combined with Figures 


1 and 2 to form a IBM PC compatible 
plug - in modem card. U4 provides bus 
buffering, while U5 provides address 
decoding. Two I/O address options are 
provided: COM1 and COM2. In 
addition, either lRQ3 or IRQ4 may be 
selected by the appropriate jumpers. 


Two other controllers are offered that 
use internal ROM for the program 
memory. This eliminates the need for 
an external EPROM. Figure 10 shows 
the VL7C245 which is intended for 
stand-alone applications. The VL7C235 
is used for bus oriented applications 
and is shown in Figure 11. Both con- 
trollers contain the Hayes compatible 
'AT’ command set. These controllers 
can be substituted in Figure 6 for U2 
and U3. 
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FIGURE 5 
COMMON MODEM CIRCUITRY 
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FIGURE 6. MODEM CONTROLLER 
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FIGURE 7. RS232 AND LED INTERFACE FOR STAND ALONE MODEM 
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FIGURE 8. POWER SUPPLY FOR STAND-ALONE MODEM 
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FIGURE 9. INTERFACE FOR PC BUS MODEM 
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FIGURE 10. ALTERNATE STAND-ALONE MODEM CONTROLLER 


27 pF 


27pF 
%%% 
AD6 


.1 


19.6608 


CRYSTAL 
H 
“MHz 


C25 Z 
XTAL1 I 7 
(325 
' 
XTAL2 I 8 
II-l 
$3 
AW'9 
IMM. 
‘.10 


11 
U2 
VCCP 
"I—I C2 
AD4 


/' 


AD3 
IH-GNDP 
—MCS 
-WR 


I2 
VL7C245 
13 
as I GNDP -j|| 
I14 
32 I S0 


15 
31 - S1 
16 
30 I S2 


17 
29 I RESET 


+5V 
ALE 
INTI 
KDV |—MRDY 
-DTR 


@|;§§wll #I wI 
ro—%U> 
O*I< 
tug$I— 
.sI%f:I 8- 


CK 
OUT 
-DSR 


39 I -RI 


38 I N.C. 
37 I --CTS 
36 I -RSLD 
35 — -AA 
34 I -HS 


1819 20 21 22 23 24 25 26 27 28 
IIIIIIIIIII 
C71 
R26 
-no |AD1|GNDl|—RTS| ss 
| sa 
ADO 
Ao2_1:Ecs 
se 
s4 
-‘TOOK 


=-' 
+5V 
‘-1’ 


404 


VL7C224A 


-MCS 
CKOUT 
KDV 
-MRDY 
OH 
-RI 
awn 
-no 
INTI 
sour 
swi 
ALE 
~ECS 
so 
s1 
s2 
sa 
s4 
ss 
ss 
-RTS 
-HS 
—AA 
-RLSD 
-osn 
-DTR 
-CTS 


ADO — AD7 


FIGURE 11. 
ALTERNATE PC BUS MODEM CONTROLLER 
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N VLSI TECHNOLOGYI mc. 
VL7C225 - VL7C235 - VL7C245 


FEATURES 
- Direct interface to the VL7C224A 
single-chip modem 


- Complete "AT" command set in 
firmware 


- Built-in 82C50B UART equivalent 


- Direct IBM PC bus interface 


- External ROM/RAM addressable 


- Two-micron CMOS technology 


- 2400 bps intelligent modem using 
just two chips 


- Compatible with industry standard 
software 


- No external buffers required 


2400 BIT-PER-SECOND MODEM 
ADVANCED COPROCESSOR FAMILY 


DESCRIPTION 
The VL7C225 family are specialized 
controllers that interface directly to the 
VL7C224A Modem to form a 2400 bps 
full duplex intelligent modem. The 
two-chip set performs all the modem 
functions as well as automatic control 
features compatible to the Hayes “AT” 
Command Set. The chip set is 
compatible to the CCITT V.22 BIS with 
V.22 fallback, Bell 212A with 103 
fallback, as well as the V.21 standard. 


The VL7C235 interfaces to a parallel 
system bus, such as the bus in the 
IBM PC, while the VL7C245 interfaces 
to an RS232 port. 


The controller receives 8-bit signal 
samples from the VL7C224A and 
performs adaptive equalization, Carrier 


phase recovery, data decode, and de- 
scrambling. 


The VL7C225, VL7C235, and VL7C245 
have identical hardware. However, they 
can be configured as a parallel 
(VL7C235), or serial (VL7C245) device 
by programming the internal ROM. The 
VL7C225 is the ROM-less version and is 
available in a 68-pin PLCC package. It is 
intended for use with external memory to 
accommodate customized firmware. 


These controllers use a bit slice core 
processor to perform digital signal 
processing (DSP) and the control 
function. Its instruction set is a fast 
subset of the 8096 instruction set. 


PIN DIAGRAMS 
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ORDER INFORMATION 
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Note: Operating temperature range is 0°C to +70°C. 
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VL7C225 SIGNAL DESCRIPTIONS (ea PINS - PARALLEL) 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


KDV 
2 
O 
This output controls the operation of the data/voice relay. When low, the 
data/voice relay is off and the phone line is connected to the phone set. 
during a data call, the VL7C225 makes this output high to operate the data! 
voice relay, disconnecting the phone set from the phone line. It may also 
be used to drive a relay for multi-line phone applications to close the A and 
A1 leads. (See Note.) 


SOUT 
3 
O 
This pin is a serial data output pin. During a data call, after the connection 
is established, the VL7C225 converts parallel data received from the 
computer bus and outputs it in a serial format to the VL7C224A modem for 
modulation. At all other times the VL7C225 holds this output in the Mark 
(high) condition. 


INTI 
5 
I 
Interrupt Input - Received from the VL7C224A at 600 Hz. Interrupt is 
detected when this pin has a low to high transition. This signal must stay 
high for at least 200 nsec. 


GNDI 
6, 34 
Ground. 


CKOUT 
7 
O 
Clock Output pin - 9.8304 MHz. 


ALE 
8 
O 
Address Latch Enable - The address on ADO-AD7 is valid at the falling 
edge of this normally low signal. 


SIN 
9 
I 
Received serial data . FSK data from the VL7C224A is input on this pin. 


XTAL1 
10 
I 
Used with XTAL2 for crystal (19.6608 MHz). 


XTAL2 
11 
O 
Crystal output pin (19.6608 MHz). 


VCCP 
18 
Positive supply (+5 V). 


—CSROM 
19 
O 
Chip Select for external ROM - Active for addresses from 8000H to FFFFH. 


GNDP 
22, 52 
Ground. 


—CSRAM 
23 
O 
Chip Select for external RAM - Active for addresses from 4000H to 7FFFH. 


-MCS 
24 
O 
Chip Select for VL7C224A - Active for addressing from 1000H to 10FFH. 


-WR 
25 
O 
Write enable - Data on ADO-AD7 is valid at the rising edge of this signal. 


-EA 
27 
I 
External Access enable - A high on this pin will cause the chip to use 
internal ROM. When this pin is low the chip will use external program 
memory. 
-RD 
29 
O 
Read enable - Data on ADO-AD7 must be valid at the rising edge of this 
signal. 


—ECS 
36 
O 
External EEPROM Chip Select - Active for addressing space from 1100H 
to 11FFH. 


RESET 
44 
I 
Master Reset - Schmitt-trigger input. A high will cause the VL7C225 to 
reset. 


A0-A2 
57, 55, 53 
I 
These three address inputs are used during read or write operation to 
select an internal UART register in the VL7C225 as shown in Table 2. The 
Divisor Latch Access Bit (DLAB) must be set high by the system software 
to access the bit rate divisor latches as shown in Table 2. (See Note.) 


Note: The use of these pins is determined by the external program. Typical designations for parallel and serial 
applications are given in the above pin descriptions 


I 
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VL7C225 - VL7C235 - VL7C245 


VL7C225 SIGNAL DESCRIPTIONS (68 PINS - PARALLEL - CONT.) 


Slgnal 
Name 
Pln 
Number 
Slgnal 
Type 
Slgnal 
Descrlptlon 


-DOST 


RDY 


-RI 


—CS 


—DIST 


OH 


INTO 


VCCP 


NC 


MAO-MA14 


ADO-AD7 


D0-D7 


59 


60 


61 


63 


64 


65 


66 


68 


26, 28, 42 
45, 62 


30, 35, 38, 
47, 49, 51 
54,56, 58 
67, 1, 4, 
12, 14, 16 


31-33, 21 
20, 17, 15 
13 


50, 48, 46 


O 


I 


O 


O 


O 


I/O 


I/O 


The system bus can write data or control words into a selected register of 
the internal UART when -DOST is low and the chip is selected. Data is 
latched on the rising edge of the signal. (See Note.) 


This open-drain output will go low upon a write or read operation on D0-D7, 
and remain low until internal data setup and hold times have been satisfied. 


The output of the ring detector in the DAA is connected to this input. A low 
level on this input indicates the “On” duration of the ring cycle. This is a 
Schmitt-trigger input, allowing for slow rising and falling signals on this pin. 
(See Note.) 


The VL7C225 is selected when this input is low. When high, the VL7C225 
forces the data bus lines, D0-D7, into a high impedance state. 


The system CPU can read data or status information from a selected 
register of the internal UART when —DIST is low and the chip is selected. 
(See Note.) 


This output controls the operation of the hookswitch relay in the DAA. 
During a data call, this output is high. lt operates the hookswitch relay 
which causes the phone line to be seized. During rotary dialing, the 
VL7C225 pulses this output at a rate often pulses per second with 
appropriate Mark/Space ratio depending on mode. (See Note.) 


This output goes high whenever any one of the following interrupt types 
has an active condition and is enabled via the IER of the internal UART: 
Receiver Line Status flag, Received Data Available, Transmitter Holding 
Register Empty, and Modem Status. It is reset low upon the appropriate 
interrupt servicing. The INTO pin is forced to a high impedance state when 
the OUT2 bit of the Modem Control Register (MCR) is low (power on state). 
(See Note.) 


Positive supply (+5 V). 


No Connect. 


15 bit address bus for external program/data access. 


8-bit bidirectional multiplexed address/data bus for addresses from 1000H 
to 11FFH. Also serves as a bidirectional data bus for external program 
memory. 


This is the 8-bit data bus comprising of three-state input/output lines. This 
bus provides bidirectional communication between the VL7C225 and the 
system CPU. Data control words and status information are transferred via 
the D0-D7 data bus. 


Note: The use of these pins is determined by the external program. Typical designations for parallel and serial 
applications are given in the above pin descriptions 
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VL7C225 SIGNAL DESCRIPTIONS (es PINS - SERIAL) 


Slgnal 
Name 
Pln 
Number 
Slgnal 
Type 
Slgnal 
Descrlptlon 


KDV 


SOUT 


INTI 


GNDI 


CKOUT 


ALE 


S IN 


XTAL1 


XTAL2 


VCCP 
-csaom 
GNDP 
—CSRAM 
-MCS 
-ANR 


-EA 


-no 


—ECS 


—RTS 


RESET 


2 


3 


5 


6, 34 


7 


8 


9 


10 


11 


18 


19 


22, 52 


23 


24 


25 


27 


29 


36 


37 


44 


O 


O 


I 


O 


O 


I 


I 


O 


O 


O 


O 


O 


O 


O 


This output controls the operation of the data/voice relay. When low, the 
data/voice relay is off and the phone line is connected to the phone set. 
during a data call, the VL7C225 makes this output high to operate the data! 
voice relay, disconnecting the phone set from the phone line. It may also 
be used to drive a relay for multi-line phone applications to close the A and 
A1 leads. (See Note.) 


This pin is a serial data output pin. The VL7C225 converts parallel data 
received from the VL7C224A or internally generated and outputs it in a 
serial format to the RS232 interface. At all other times the VL7C225 holds 
this output in the Mark (high) condition. 


Interrupt Input - Received from the VL7C224A at 600 Hz. Interrupt is 
detected when this pin has a low to high transition. This signal must stay 
high for at least 200 nsec. 


Ground. 


Clock Output pin - 9.8304 MHZ. 


Address Latch Enable - The address on ADO-AD7 is valid at the falling 
edge of this normally low signal. 


Received serial data . Data from the RS232 Interface is input on this pin. 


Used with XTAL2 for crystal (19.6608 MHz). 


Crystal output pin (19.6608 MHz). 


Positive supply (+5 V). 


Chip Select for external ROM - Active for addresses from 8000H to FFFFH. 


Ground. 


Chip Select for external RAM - Active for addresses from 4000H to 7FFFH. 


Chip Select for VL7C224A - Active for addressing from 1000H to 10FFH. 


Write enable - Data on ADO-AD7 is valid at the rising edge of this signal. 


External Access enable - A high on this pin will cause the chip to use 
internal ROM. When this pin is low the chip will use external program 
memory. 


Read enable - Data on ADO-AD7 must be valid at the rising edge of this 
signal. 


External EEPROM Chip Select - Active for addressing space from 1100H 
to 11FFH. 


Request to Send - Input from RS232 interface. (See Note.) 


Master Reset - Schmitt-trigger input. A high will cause the VL7C225 to 
reset. 


Note: The use of these pins is determined by the external program. Typical designations for parallel and serial 
applications are given in the above pin descriptions 
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VL7C225 - VL7C235 - VL7C245 


VL7C225 SIGNAL DESCRIPTIONS (68 PINS -SERIAL - CONT.) 


Slgnal 
Name 
Pln 
Number 
Slgnal 
Type 
Slgnal 
Descrlptlon 


-HS 


-AA 


-RLSD 


-CTS 


-RI 


—DSR 


-DTR 


OH 


-MRDY 


VCCP 


N.C. 


MAO-MA14 


ADO-AD7 


S0-S6 


53 


5 


57 


59 


61 


63 


64 


65 


66 


68 


26, 28, 42, 
45, 60, 62 


30, 35, 38 
47, 49, 51 
54, 56, 58 
67, 1, 4, 
12, 14, 16 


31-33, 2, 
20, 17, 15 
13 


50, 48, 46, 
43, 41, 40, 
39 


O 


O 


O 


O 


I 


O 


I 


O 


O 


O 


I/O 


I 


This output, when low, indicates that the modem is in the high speed (2400 
bps) mode. When high, it indicates that it is in the low speed modes. (See 
Note.) 


This output is low when the VL7C225 is set for auto-answer mode. The 
output goes high during each ring. If the device is not set to answer the 
phone, this output goes low each time the phone rings. (See Note.) 


This output goes low when the VL7C225 detects a carrier signal from the 
remote modem. If the connection is broken or never established, it 
remains high. (See Note.) 


This output goes low to indicate the modem is ready to receive data from 
the RS232 interface. (See Note.) 


The output of the ring detector in the DAA is connected to this input. A low 
level on this input indicates the “On” duration of the ring cycle. This is a 
Schmitt-trigger input, allowing for slow rising and falling signals on this pin. 
(See Note.) 


This output indicates the status of the modem. Normally connected to the 
RS232 interface. (See Note.) 


This input from the RS232 interface may be used to control the status of 
the modem. (See Note.) 


This output controls the operation of the hookswitch relay in the DAA. 
During a data call, this output is high. It operates the hookswitch relay 
which causes the phone line to be seized. During rotary dialing, the 
VL7C225 pulses this output at a rate often pulses per second with 
appropriate Mark/Space ratio depending on mode. (See Note.) 


This output goes low when the mode is ready for operation. (An LED 
indicator is normally driven by this pin.) (See Note.) 


Positive supply (+5 V). 


No Connect. 


15 bit address bus for external program/data access. 


8-bit bidirectional multiplexed address/data bus for addresses from 1000H 
to 11FFH. 


7-bit input port for sensing switch settings. 


Note: The use of these pins is determined by the external program. Typical designations for parallel and serial 
applications are given in the above pin descriptions 
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VL7C235 SIGNAL DESCRIPTIONS (44 PINS) 


Slgnal 
Name 
Pln 
Number 
Slgnal 
Type 
Slgnal 
Descrlptlon 


KDV 


SOUT 


INTI 


CKOUT 


ALE 


S IN 


XTAL1 


XTAL2 


VCCP 


GNDP 


-MCS 


-WR 


-RD 


GNDI 


—ECS 


RESET 


A0-A2 


-DOST 


RDY 


1 


2 


3 


4 


5 


6 


7 


8 


12 


15,33 


16 


17 


18 


22 


23 


29 


36,35, 34 


37 


O 


O 


I 


O 


O 


I 


I 


O 


O 


O 


O 


O 


I 


I 


38 
O 


This output controls the operation of the data/voice relay. When low, the 
data/voice relay is off and the phone line is connected to the phone set. 
during a data call, the VL7C235 makes this output high to operate the datal 
voice relay, disconnecting the phone set from the phone line. It may also 
be used to drive a relay for multi-line phone applications to close the A and 
A1 leads. 
' 


This pin is a serial data output pin. During a data call, after the connection 
is established, the VL7C235 converts parallel data received from the 
computer bus and outputs it in a serial format to the VL7C224A modem for 
modulation. At all other times the VL7C235 holds this output in the Mark 
(high) condition. 


Interrupt Input - Received from the VL7C224A at 600 Hz. Interrupt is 
detected when this pin has a low to high transition. This signal must stay 
high for at least 200 nsec. 


Clock Output pin - 9.8304 MHz. 


Address Latch Enable - The address on ADO-AD7 is valid at the falling 
edge of this normally low signal. 


Received serial data . FSK data from the VL7C224A is input on this pin. 


Used with XTAL2 for crystal (19.6608 MHz). 


Crystal output pin (19.6608 MHz). 


Positive supply (+5 V). 


Ground. 


Chip Select for VL7C224A - Active for addressing from 1000H to 10FFH. 


Write enable - Data on ADO-AD7 is valid at the rising edge of this signal. 


Read enable - Data on ADO-AD7 must be valid at the rising edge of this 
signal. 


Ground. 


External EEPROM Chip Select - Active for addressing space from 1100H 
to 11FFH. 


Master Reset - Schmitt-trigger input. A high will cause the VL7C235 to 
reset. 


These three address inputs are used during read or write operation to 
select an internal UART register in the VL7C235 as shown in Table 2. The 
Divisor Latch Access Bit (DLAB) must be set high by the system software 
to access the bit rate divisor latches as shown in Table 2. 


The system bus can write data or control words into a selected register of 
the internal UART when -DOST is low and the chip is selected. Data is 
latched on the rising edge of the signal. 


This open-drain output will go low upon a write or read operation on D0-D7, 
and remain low until internal data setup and hold times have been satisfied. 
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L7C235 SIGNAL DESCRIPTIONS (44 PINS - com.) 
V 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


—RI 
39 
I 
The output of the ring detector in the DAA is connected to this input. A low 
level on this input indicates the "On” duration of the ring cycle. This is a 
Schmitt-trigger input, allowing for slow rising and falling signals on this pin. 
-CS 
40 
I 
The VL7C235 is selected when this input is low. When high, the VL7C235 
forces the data bus lines, D0-D7, into a high impedance state. 


—DIST 
41 
I 
Thesystem CPU can read data or status information from a selected 
register of the internal UART when —DIST is low and the chip is selected. 


OH 
42 
O 
This output controls the operation of the hookswitch relay in the DAA. 
During a data call, this output is high. It operates the hookswitch relay 
which causes the phone line to be seized. During rotary dialing, the 
VL7C235 pulses this output at a rate often pulses per second with 
appropriate Mark/Space ratio depending on mode. 


INTO 
43 
O 
This output goes high whenever any one of the following interrupt types 
has an active condition and is enabled via the IER of the internal UART: 
Receiver Line Status flag, Received Data Available, Transmitter Holding 
Register Empty, and Modem Status. It is reset low upon the appropriate 
interrupt servicing. The INTO pin is forced to a high impedance state when 
the OUT2 bit of the Modem Control Register (MCR) is low (power on state). 


VCCI 
44 
Positive supply (+5 V). 


ADO-AD7 
19, 20, 21, 
I/O 
8-bit bidirectional multiplexed address/data bus for addresses from 1000H 
14, 13, 11, 
to 11FFH. Also serves as bidirectional data bus for external program 
10, 9 
memory. 


D0-D6 
32, 31, 30, 
I/O 
This is the 8-bit data bus comprising of three-state input/output lines. This 
28, 27, 26, 
bus provides bidirectional communication between the VL7C235 and the 
25, 24 
system CPU. Data control words and status information are transferred via 
the D0-D7 data bus. 
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VL7C245 SIGNAL DESCRIPTIONS (44 PINS) 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


KDV 
1 
O 
This output controls the operation of the data/voice relay. When low, the 
data/voice relay is off and the phone line is connected to the phone set. 
during a data call, the VL7C245 makes this output high to operate the data/ 
voice relay, disconnecting the phone set from the phone line. It may also 
be used to drive a relay for multi-line phone applications to close the A and 
A1 leads. 


SOUT 
2 
O 
This pin is a serial data output pin. The VL7C245 converts parallel data 
received from the VL7C224A or internally generated and outputs it in a 
serial format to the RS232 interface. At all other times the VL7C245 holds 
this output in the Mark (high) condition. 


INTI 
3 
I 
Interrupt Input - Received from the VL7C224A at 600 Hz. Interrupt is 
detected when this pin has a low to high transition. This signal must stay 
high for at least 200 nsec. 
CKOUT 
4 
o 
Clock Output pin - s.eso4 MHz. 


ALE 
5 
O 
Address Latch Enable - The address on ADO-AD7 is valid at the falling 
edge of this normally low signal. 


SIN 
6 
I 
Received serial data . Data from the RS232 interface is input on this pin. 


XTAL1 
7 
I 
Used with XTAL2 for crystal (19.6608 MHz). 


XTAL2 
8 
O 
Crystal output pin (19.6608 MHz). 


VCCP 
12 
Positive supply (+5 V). 


GNDP 
15, 33 
Ground. 


-MCS 
16 
O 
Chip Select for VL7C224A - Active for addressing from 1000H to 10FFH. 


-WR 
17 
O 
Write enable - Data on ADO-AD7 is valid at the rising edge of this signal. 


-RD 
18 
O 
Read enable - Data on ADO—AD7 must be valid at the rising edge of this 
signal. 


GNDI 
22 
Ground. 


—ECS 
23 
O 
External EEPROM Chip Select - Active for addressing space from 1100H 
to 11FFH. 
-RTS 
24 
I 
Request to Send — Input for RS232 interface. 


RESET 
29 
I 
Master Reset - Schmitt-trigger input. A high will cause the VL7C245 to 
reset. 


-HS 
34 
O 
This output, when low, indicates that the modem is in the high speed (2400 
bps) mode. When high, it indicates that it is in the low speed modes. 


-AA 
35 
O 
This output is low when the VL7C245 is set for auto-answer mode. The 
output goes high during each ring. If the device is not set to answer the 
phone, this output goes low each time the phone rings. 


-RLSD 
36 
O 
This output goes low when the VL7C245 detects a carrier signal from the 
remote modem. If the connection is broken or never established, it 
remains high. 
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VL7C245 SIGNAL DESCRIPTIONS (44 PINS - com.) 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


—CTS 
37 
O 
This output goes low to indicate the modem is ready to receive data from 
the RS232 interface. 


N.C. 
38 
No Connect. 


-RI 
39 
I 
The output of the ring detector in the DAA is connected to this input. A low 
level on this input indicates the "On" duration of the ring cycle. This is a 
Schmitt-trigger input, allowing for slow rising and falling signals on this pin. 


-DSR 
40 
O 
This output indicates the status of the modem. Normally connected to the 
RS232 interface. 
-DTR 
41 
I 
This input from the RS232 interface may be used to control the satus of the 
modem. 
' 


OH 
42 
O 
This output controls the operation of the hookswitch relay in the DAA. 
During a data call, this output is high. It operates the hookswitch relay 
which causes the phone line to be seized. During rotary dialing, the 
VL7C245 pulses this output at a rate of ten pulses per second with 
appropriate Mark/Space ratio depending on mode. 


-MRDY 
43 
O 
This output goes low when the modem is ready for operation. (An LED 
indicator is normally driven by this pin.) 


VCCI 
44 
Positive supply (+5 V). 


ADO-AD7 
19-21, 14 
I/O 
8-bit bidirectional multiplexed address/data bus for addresses from 1000H 
13,11,10, 
to11FFH. 
9 


S0-S6 
32, 31, 30, 
l 
7-bit input port for sensing switch settings. 
28, 27, 26, 
25 
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VL7C235 SIGNAL DESCRIPTIONS (40 PINS ) 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


KDV 
1 
O 
This output controls the operation of the data/voice relay. When low, the 
data/voice relay is off and the phone line is connected to the phone set. 
during a data call, the VL7C235 makes this output high to operate the data/ 
voice relay, disconnecting the phone set from the phone line. It may also 
be used to drive a relay for multi-line phone applications to close the A and 
A1 leads. 


SOUT 
2 
O 
This pin is a serial data output pin. During a data call, after the connection 
is established, the VL7C235 converts parallel data received from the 
computer bus and outputs it in a serial format to the VL7C224A modem for 
modulation. At all other times the VL7C235 holds this output in the Mark 
(high) condition. 


INTI 
3 
I 
Interrupt Input - Received from the VL7C224A at 600 Hz. Interrupt is 
detected when this pin has a low to high transition. This signal must stay 
high for at least 200 nsec. 


CKOUT 
4 
O 
Clock Output pin - 9.8304 MHz. 


ALE 
5 
O 
Address Latch Enable - The address on ADO-AD7 is valid at the falling 
edge of this normally low signal. 


SIN 
6 
I 
Received serial data . FSK data from the VL7C224A is input on this pin. 


XTAL1 
7 
I 
Used with XTAL2 for crystal (19.6608 MHz). 


XTAL2 
8 
O 
Crystal output pin (19.6608 MHz). 


-MCS 
14 
O 
Chip Select for VL7C224A - Active for addressing from 1000H to 10FFH. 


-WR 
15 
O 
Write enable - Data on ADO-AD7 is valid at the rising edge of this signal. 


-RD 
16 
O 
Read enable - Data on ADO-AD7 must be valid at the rising edge of this 
signal. 


GND 
20 
Ground. 


—ECS 
23 
External EEPROM Chip Select - Active for addressing space from 1100H 
to 11FFH. 


RESET 
27 
I 
Master Reset - Schmitt-trigger input. A high will cause the VL7C235 to 
reset. 


A0-A2 
33, 32, 31 
These three address inputs are used during read or write operation to 
select an internal UART register in the VL7C235 as shown in Table 2. The 
Divisor Latch Access Bit (DLAB) must be set high by the system software 
to access the bit rate divisor latches as shown in Table 2. 


-DOST 
34 
I 
The system bus can write data or control words into a selected register of 
the internal UART when -DOST is low and the chip is selected. Data is 
latched on the rising edge of the signal. 
-RI 
35 
I 
The output of the ring detector in the DAA is connected to this input. A low 
level on this input indicates the "On" duration of the ring cycle. This is a 
Schmitt-trigger input, allowing for slow rising and falling signals on this pin. 


416 


® VLSI TECHNOLOGY, INC. 
VL7C225 - VL7C235 - VL7C245 


vuczss SIGNAL DESCRIPTIONS (40 PINS - com.) 
I 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


—CS 
36 
The VL7C235 is selected when this input is low. When high, the VL7C235 
forces the data bus lines, DO-D7, into a high impedance state. 


—DIST 
37 
I 
The system CPU can read data or status information from a selected 
. 
register of the internal UART when —DIST is low and the chip is selected. 


OH 
38 
O 
This output controls the operation of the hookswitch relay in the DAA. 
During a data call, this output is high. it operates the hookswitch relay 
which causes the phone line to be seized. During rotary dialing, the 
VL7C235 pulses this output at a rate of ten pulses per second with 
appropriate Mark/Space ratio depending on mode. 


INTO 
39 
O 
This output goes high whenever any one of the following interrupt types 
has an active condition and is enabled via the IER of the internal UART: 
Receiver Line Status flag, Received Data Available, Transmitter Holding 
Register Empty, and Modem Status. lt is reset low upon the appropriate 
interrupt sen/icing. The INTO pin is forced to a high impedance state when 
the OUT2 bit of the Modem Control Register (MCR) is low (power on state). 


VCC 
40 
Positive supply (+5 V). 


ADO-AD7 
17-19, 13 
I/O 
8-bit bidirectional multiplexed address/data bus for address from 1000H 
12,11,10 
to11FFH. 
9 


D0-D7 
30, 29, 28 
I/O 
This is the 8-bit data bus comprising of three-state input/output lines. This 
26, 25, 24 
bus provides bidirectional communication between the VL7C235 and the 
23, 22 
system CPU. Data control words and status information are transferred via 
the DO-D7 data bus. 
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VL7C245 SIGNAL DESCRIPTIONS (40 PINS) 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


KDV 
1 
O 
This output controls the operation of the data/voice relay. When low, the 


, 
data/voice relay is off and the phone line is connected to the phone set. 
during a data call,the VL7C245 makes this output high to operate the data/ 
voice relay, disconnecting the phone set from the phone line. It may also 
be used to drive a relay for multi-line phone applications to close the A and 
A1 leads. 


SOUT 
2 
O 
This pin is a serial data output pin. The VL7C245 converts parallel data 
received from the VL7C224A or internally generated and outputs it in a 
serial format to the RS232 interface. At all other times the VL7C245 holds 
this output in the Mark (high) condition. 


INTI 
3 
I 
Interrupt Input - Received from the VL7C224A at 600 Hz. Interrupt is 
detected when this pin has a low to high transition. This signal must stay 
high for at least 200 nsec. 


CKOUT 
4 
O 
Clock Output pin - 9.8304 MHz. 


ALE 
5 
O 
Address Latch Enable - The address on ADO-AD7 is valid at the falling 
edge of this normally low signal. 


SIN 
6 
I 
Received serial data . Data from the RS232 interface is input on this pin. 


XTAL1 
7 
I 
Used with XTAL2 for crystal (19.6608 MHz). 


XTAL2 
8 
O 
~ 
Crystal output pin (19.6608 MHz). 


-MCS 
14 
O 
Chip Select for VL7C224A - Active for addressing from 1000H to IOFFH. 


--WR 
15 
O 
Write enable - Data on ADO-AD7 is valid at the rising edge of this signal. 


-RD 
16 
O 
Read enable - Data on ADO-AD7 must be valid at the rising edge of this 
signal. 


GND 
20 
Ground. 


—ECS 
21 
O 
External EEPROM Chip Select - Active for addressing space from 1100H 
to 11FFH. 
-RTS 
22 
Request to Send - Input from RS232 interface. 


RESET 
27 
I 
Master Reset - Schmitt-trigger input. A high will cause the VL7C245 to 
reset. 
-HS 
31 
O 
This output, when low, indicates that the modem is in the high speed (2400 
bps) mode. When high, it indicates that it is in the low speed modes. 


-AA 
32 
O 
This output is low when the VL7C245 is set for auto-answer mode. The 
output goes high during each ring. If the device is not set to answer the 
phone, this output goes low each time the phone rings. 


-RLSD 
33 
O 
This output goes low when the VL7C245 detects a carrier signal from the 
remote modem. If the connection is broken or never established, it 
remains high. 


418 


® VLSI TECHNOLOGY, mc. 
VL7C225 - VL7C235 - VL7C245 


1.10245 SIGNAL DESCRIPTIONS (40 PINS - com.) 
V 


Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


-CTS 
34 
O 
This output goes low to indicate the modem is ready to receive data from 
the RS232 interface. 


-RI 
35 
I 
The output of the ring detector in the DAA is connected to this input. A 
level on this input indicates the "On" duration of the ring cycle. This is a 
Schmitt-trigger input, allowing for slow rising and falling signals on this pin. 


—DSR 
36 
I/O 
This output indicates the status of the modem. Normally connected to the 
RS232 interface. 


-DTR 
37 
I 
This input from the RS232 interface may be used to control the status of 
the modem. 


OH 
38 
O 
This output controls the operation of the hookswitch relay in the DAA. 
During a data call, this output is high. It operates the hookswitch relay 
which causes the phone line to be seized. During rotary dialing, the 
VL7C245 pulses this output at a rate often pulses per second with 
appropriate Mark/Space ratio depending on mode. 
-MRDY 
39 
O 
This output goes low when the modem is ready for operation. (An LED 
indicator is normally driven by this pin.) 


VCC 
40 
Positive supply (+5 V). 


ADO—AD7 
17-19, 13 
V0 
8-bit bidirectional multiplexed address/data bus for addresses from 1000H 
12,11,10 
to11FFH. 
9 


SO-S6 
30, 29, 28, 
I 
7-bit input port for sensing switch settings. 
26, 25, 24, 
23 
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FIGURE 1. MAC BLOCK DIAGRAM 
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FIGURE 2 
MAC MEMORY MAP 


INSTRUCTIONS 


VIA MAO - 14 Bus (ADDRESS) 
AND ADO - AD7 BUS (DATA) 
(—CSROM ACTIVE) 


VIA MAO - 14 BUS (ADDRESS) 
AND ADO - AD7 BUS (DATA) 
(—CSRAM ACTIVE) 


3FFF 
INTERNAL ROM 


o‘no 


ID 
INTERRUPT VECT 
RESET VECT 


UNACCESSABLE 


VIA ADO - AD7 BUS 
(—ECS ACTIVE) 


VIA ADO - AD7 Bus 
(-MCS ACTIVE) 


UNACCESSABLE 
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OPERANDS 
(DIRECT ADDRESSING) 


IF PAGE BIT SET: 


OOFF 


UNACCESSAB LE 


002F 
SCRATCHPAD RAM 
0000 


IF PAGE BIT CLEAR: 


INTERNAL 
°°FF 
SCRATCHPAD 
RAM 


0000 
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OPERANDS 
(INDIRECT ADDRESSING) 


SAME AS DIRECT 
ADDRESSING 
EXCEPT 


- SCRATCHPAD RAM ON PAGE 2 IS 
ADRESSABLE AS LOCATIONS 0100 
TO 012F 


— INTERNAL REGISTERS AT 
LOCATIONS 0180 TO 019F ARE 
ACCESSABLE USING THIS MODE 


FUNCTIONAL DESCRIPTION 
HARDWARE ARCHITECTURE 
Figure 1 shows the internal block 
diagram of the MAC. The MAC is 
organized with two buses that intercon- 
nect its four main logic sections. The 
two buses are the internal data bus 
(DB) and address bus . The four 
sections of the device are: 


1. PLA/RALU/control section 
2. RAM, register file and I/O ports 
3. Program memory and memory 
control 
4. UART 


The two bus architecture was chosen to 
allow the MAC to execute a subset of 
the 8096 instruction set as fast or faster 
than the 8096 itself. The device is 
intended to run at 9.8304 MHz. A 
typical three operand instruction 
effectively executes in 10 clock cycles 
or 1.02 p8. The signed 16 x 16 multiply 
operation requires 34 clock cycles or 
3.3 Its. A comparison of execution 
times to those of an 8096 is given in 
Table 9. 


The internal data bus is an 8-bit bus 
that interconnects all tour sections of 
the device. All internal data travels on 
DB. The address bus is a 16-bit output 
only bus from the RALU that provides 
addresses to the memory and register 
sections of the device. 


The control/PLA/RALU section controls 
MAC operations and performs all of the 
required computation functions. The 
internal processor consists of a micro- 
control PLA and a 16-bit registered 
arithmetic/logic unit which inputs 8096 
instruction opcodes and generates the 
control sequences necessary to 
implement the instructions. The RALU 
performs instruction execution, operand 
address calculation, jump address 
calculation, program sequencing, and 
stack control. The program counter 
(PC) and stack pointer (SP) are 
contained within the RALU. On reset, 
the PC points to address 2000 and the 
SP points to 0131. The RALU is imple- 
mented with the 2901 compiler. 


The RAM and register file section of the 
MAC includes RAM and the I/O ports of 
the device. These locations are all 
treated as registers and may be 
accessed in register direct mode. 
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However, program code can't be 
executed from registers. The UART 
and I/O registers are functionally, but 
not physically, part of the register 
section. The UART registers are 
accessed via indirect addressing mode 
only. There are 304 bytes of RAM to 
support DSP functions and the modem 
command set. 


The memory section of the MAC 
includes the program ROM and the 
external memory interface. The device 
contains 8k bytes of program ROM. 
External memory interface allows the 
MAC to access program or data storage 
from external memory. 


The UART section of the device 
implements the industry standard 
82508 UART. In its parallel configura- 
tion the MAC appears as an 8250B to 
the user via the D0 - D7 data bus. The 
UART contains dual-port capability to 
allow the user and the internal proces- 
sor access to its internal registers 
independently. The VO lines of this 
section may be configured for use in 
serial modems also and this is internally 
controlled via a register bit. 


MEMORY DESCRIPTION 
The memory map of the MAC is shown 
in Figure 2 . The accessibility of 
memory address locations is dependent 
on whether the MAC is attempting to 
fetch an instruction or an operand as 
shown in the figure. Access of the 
internal scratchpad RAM and internal 
registers is via a paged memory 
system. The first 256 bytes of RAM 
may be directly addressed if the page 
bit in the GCR register is clear. The 
remaining 48 bytes of RAM and the 
registers are mapped as the second 
page of low memory and may either be 
indirectly addressed as locations 0100 
to 019F or directly addressed as 0000 
to 009F if the page mode bit has been 
set. 


External Read/Wrlte 
Three different types of external 
memory operations are defined. 


A) For addresses from 1000H to 
11FFH: 
These external operations occur 
through the AD bus. and take six 
clock cycles, four more than most 
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internal operations. This space is 
intended for MAP & EEROM inter- 
faces, however, instructions and 
data can also be fetched from this 
memory space. 


B) For addresses from 4000H to 
7FFFH: VL7C225 only. 
This memory space is used for 
external DATA storage. The MAC 
can access this external RAM space 
through MA bus and AD bus. These 
are six clocks memory bytes for 
easy access. Program instructions 
may also be fetched from these 
locations. 


C) For addresses from 8000H to 
FFFFH: VL7C225 only. 
These locations can be used to fetch 
instructions from external program 
storage via the MA and AD buses. 
These operations are exactly the 
same as internal ROM fetches which 
take 2 clock cycles. 


INTERNAL REGISTER DESCRIP- 
TIONS 
This section contains a description of 
each of the registers in the MAC . All of 
the registers of the device are 8-bits 
wide. The registers are made up of bits 
that are either read-only (RO) or are 
read/write (R/W). Register addresses 
are shown in Table 1. 


UART Registers 
Table 2 summarizes the organization of 
the UART registers. For a detailed 
explanation consult an 82C50B data 
sheet 


UART Monltor Reglster (UMR) 
The UART Monitor register allows the 
processor to monitor UART operations. 
A read operation to the UART Monitor 
register will clear Bit 0 to Bit 4. See 
Table 3. 


Switch Port Reglster (SWPXserial 
configuration only) 
The Switch PoIt is a 7-bit input port 
used only in the serial configuration of 
the MAC. It allows for reading of the 
external switches in a stand-alone 
modem application. See Table 4. 


Tlmer Reglster (TIM) 
The 'I"Imer includes an 11 bit counter 
and a timer flip-flop. It is used to aid in 
software timing functions. The counter 


VLSI TECHNOLOGY mc. 
N) 
. 
VL7C225 - VL7C235 - VL7C245 


is not readable, however it can be reset 
by a write to this register. The timer flip- 
flop bit can be read to test it is set, 
indicating that the timer has completed 
one divide by 2048 cycle on the 9.8304 
MHz internal clock. Reading or writing 
this register resets this bit and clears 
the divide by 2048 counter. This may 
be used to generate an interrupt at 4.8 
KHz for internal processing. 


General Control Reglster (GCR 
GCR (General Control Register) 
contains a miscellaneous set of control 
and status bits. See Table 6. 
Processor Status Byte (PSB) 
This register contains the result codes 
for each program instruction execution 
and the global interrupt status and 
enable bits. See Table 7. 


Interrupt Control Reglster (ICR) 
This is an 8 bit register to enable or 
disable each of the four interrupt 
sources and to record the interrupt 
sources. The upper four bits are readl 
write registers which enable the 
interrupts, while the lower four bits are 
read only registers indicating which 
event(s) generated an interrupt. A read 
operation to the register will automati- 
cally clear these lower four bits. 


BITO' 


BIT1 


BIT2: 


BITS 


BIT4 
BITS 


BlT6 


BIT7 


“1” indicates UART requested an 
interrupt. 
"1" indicates -RI pin leading 
edge requested an interrupt. 
"1" indicates TIMER overflow 
requested an interrupt. 
“1" indicates EXTERNAL source 
requested an interrupt via the 
INTI pin 
"1" to enable UART interrupt. 
"1" to enable —RI pin leading 
edge interrupt. 
“1" to enable TIMER overflow 
interrupt 
"1" to enable EXTERNAL 
interrupt 


Any one of these four interrupts will 
drive the processor to address 2004. 
From there the software can check 
interrupt sources and do priority control 
to branch to different service routines. 


VL7C235 AND VL7C245 DIFFER- 
ENCES 
The primary differences between the 
VL7C225 and the VL7C235 and 
VL7C245 is that the later have no 


provision for accessing external RAM or 
program memory via the MA bus and 
that these devices contain internal ROM 
pre-programmed to implement either a 
stand-alone serial modem (VL7C245) or 
PC bus oriented modem (VL7C235) 
featuring a modem command set 
compatible with the Hayes ‘AT’ set. 


Another difference is that in order to 
allow external ROM to function the 
VL7C225 has a short code segment at 
the reset and interrupt vector locations 
of its internal ROM which causes the 
MAC to vectors to locations 8000 and 
8004 for these events. 


APPLICATIONS INFORMATION 
For complete applications information 
and circuit diagrams of the VL7C225/ 
235/245 family's use in a V.22 bis 
modem using the VL7C224A 2400 bps 
Modem IC, please referto the 
VL7C224A data sheet. 


SOFTWARE ARCHITECTURE 
Operand Types 
MAC instructions may use four types of 
operands: Short Integers, Integers, 
Long Integers, and Bits. 


Short Integers - Short integers are 8-bit 
signed 2's complement variables. 
Arithmetic operations which generate 
results outside the range -128 and +127 
will set the overflow bit in the Processor 
Status Byte (PSB). There are no 
alignment restrictions on short integers. 


integers - Integers are 16-bit signed 2's 
complement variables. Arithmetic 
operation which generate results 
outside the range -32768 and +32767 
will set the overflow bit in the PSB. The 
least significant byte of the integers is at 
the even byte address and the most 
significant byte is at the next higher 
(odd) address. Therefore the integers 
must be aligned at even byte bounda- 
ries in the address space. The address 
of a integer is the address of its least 
significant byte (always an even 
address). 


Bits - The bits within the bytes of the 
register file are numbered from 0 to 7 
with 0 referring to the LSB. The only 
instructions that use bit addressing are 
JBC and JBS. 


Long Integers - Long integers are 32-bit 
signed 2's complement variables. The 
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result of a 16 x 16-bit multiply will be 
stored as a long integer. Only SHRL 
and SHLL can manipulate this data 
type. Long integers are addressed by 
the address of their least significant 
byte in the register file. They should be 
aligned such that their address is evenly 
divisible by 4. The most significant byte 
of a long integer resides on "address" 
+3, where "address" is the long 
integer's address. 


Operand Addressing 
Three types of addressing are allowed: 


Immediate Addressing - This is a direct 
address field within the instruction. For 
short integers, this is an 8-bit field, 
whereas, for the integers this is a 16-bit 
field. Only one operand within an 
instruction can be immediate reference 
type. This operand must always be the 
last (right most) operand within an 
instruction. 
e.g. 
ADD AX,BX,#340H is allowed 


ADD AX,#340H, BX is NOT 
allowed 


Register Direct Addressing - In this 
mode an 8-bit field is used to access a 
location from the 304 byte scratchpad 
RAM or internal resisters. The address 
must conform to the alignment rules. 
e.g. 
ADD AX, BX : AX, BX must be 
“even” numbers and from 00H to 
FFH in range 


ADDB AX, BX 
: AX, BX can be 
“odd” or "even" and from 00H to 
FFH in range 


Indirect Addressing - A memory location 
can be addressed indirectly by placing 
its 16-bit address in a internal RAM 
location. Only one operand (the right 
most operand) within an instruction can 
be indirect. 
e.g. 
ADDB AX, BX, [CX] is allowed 


ADDB AX, [CX], BX is NOT 
allowed 


Instruction Set 
The MAC instruction set is a subset of 
Intel 8096 instruction set and is shown 
in Table 8. The object codes, formats, 
and the flags they effect are identical to 
those of 8096. The differences are: 


- No VT or ST flags exist in the MAC. 
- Internal register locations can only be 
accessed by using indirect address- 
ing. 


The operands refer IO One or more 
Interrupt Structure 
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UART interrupts - Interrupt from UART: 
bytes Oi the internal RAM. ROM 
Four interrupt sources exist in the MAC, 
Parallel Configuration: From UMR 
i°°aii°"$ Ca" °"iY be addfeeeed 
namely the external interrupt, timer 
register. 
U9-ing indireei addressing. 
interrupt, ring leading edge interrupt, 
Serial Configuration: In this configura- 
H a memory mcatidn is addressed 
and UART Interrupt. The Interrupt 
tion, the Interrupt signal from the UART 
between 1000H and 11 FFH an 
S8l'VIC8 routine address is 2004H. 
external six clock multiplexed bus 
External interrupt - A low to high 


is used directly as an interrupt source to 
the internal CPU. 


epelaiien ie i"iiiaied- The mUiiiPieXed 
transition on the INTI pin initiates this 
address/data will use AD7-ADO bus. 
interrupt. 


Whe" U$i09 ST er 3TB epeiaiiee. 
Timer interrupt - ‘Fmer overflow 
the destinations are always consid- 
interrupt - 4.8 KHz frequency 
ered to be indirect addresses. 
°'9' 
ST AX’ [Bx] is a"°‘”°d 
§'"I§l§i§'"§d°§g§l}IT“iI.'“§i gliiniigied 
ST AX, Bx is NOT allowed 
Y 
9 
9 
9 
P 
P ' 


Name 


UART Registers: 


Receive Buffer 


Transmit Buffer 


interrupt Enable 


Interrupt ID 


Line Control 


Modem Control 


Line Status 


Modem Status 


Scratch Pad (8 Bit) 


Divisor Latch LSB 


Divisor Latch MSB 


Internal Registers: 


UART Monitor 


Switch Port 


GCR (General Control Register) 


Timer 


PSB (Processor Status Byte) 


ICR (Interrupt Register) 


TABLE 1. REGISTER ADDRESS MAP 


Internal 
External 
(Indirect Addressing Only) 
(A0 - A3) 


ABV 
ADR 
R/W 
ADR 
R/W 


E!EE!!|!!!!E!E!E!!| 


RBR 
18OH 
OOH‘ 
RO 


THR 
18AH 
OOH‘ 
WO 


01H’ 
R/W 


182H 
02H 
RO 


LCR 
03H 
R/W 


MCR 
184H 
04H 
R/W 


LSR 
05H 
R/W 


186H 
06H 
R/W 


STR 
187H 
07H 
R/W 


D 
188H 
OOH“ 
R/W 


DLM 
189H 
01H“ 
R/W 
' 


UMR 
18BH 


SWP 
18DH 


GCR 


M 


192H 


DLAB bit in UART LCR register must be zero for access. 
DLAB bit in UART LCR register must be one for access. 
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TABLE 2. UART REGISTERS 


Register 
Reglster Bit Number 


Mnemonlc 


RBR 


THR 


IER 


IIR 


LCR 


MCR 


LSR 


MSR 


DLM 


DLL 


STR 


BtO 
BI 
Bt2 
Bt3 
BIt7 
B t 4 
B t 5 
B t 6 
@@@ 
Data 


0 


Interrupt 
Interrupt 
0 
ID Bit 0 
ID Bit 1 


0 =1 Stop 
1 = Parity 
1 == Even 
1 = Stick 
1 = Set 
DLAB 
Bit 
Enable 
Parity 
Parity 
Break 


1 =- 2 Stop 
Bits 


Request 
OUT1 
OUT2 
No 
0 
to Send 
0 = INT 
Function 
Output 
to HI-Z 


Data 
Overrun 
Parity 
Framing 
Break 
THRE 
TSRE 
0 
Ready 
Error 
Error 
Error 
Interrupt 


Trailing 
Delta 
1 (CTS) 
RLSD 
Edge Ring 
RLSD 
%@ 
Dam 
% 
Dam 


Data 


Receive 
THRE 
Receive 
Modem 
Data 
Interrupt 
Line 
Status 
Available 
Enable 
Status 
Interrupt 
Interrupt 
Interrupt 
Enable 
(Enable 
Enable 


0 If 
Interrupt 
Pending 


0 =- 7 Bit 
Data 


1 = 8 Bit 
Data 


Data 
Terminal 
Ready 
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TABLE 3. UART MONITOR (UMR) 


Bit 
Bit 
Bit 
Number 
Name 
Descrlptlon 


7 
RTRST 
Reset Receiver and Transmitter. When set high, both receiver and transmitter will be put 
into reset state. 


6 
CM 
UART Command/Modem Control. When set high, the UART is placed in modem mode and 
data from SIN and SOUTflows to/from the UART. When low, SOUT is forced high and SIN 
is disconnected from the UART receive register. At reset it is low. This bit together with 
bit 6 in LCR can used for bit by bit echoing. In serial mode the user can set bit 6 of LCR -= 1, 
and set CM = to the complement of the RDI bit to echo a bit out the SOUT pin. 


5 
Receive Data Input. This bit monitors the Rxd input of the UART. 


4 
D 


71 
'11 


Divisor Latch Flag. This bit indicates if a new baud rate count has been written to the 
Divisor Latch. 


3 
LCF 
Line Control Flag. This bit indicates if the line control register has been written. 


2 
Transmit Buffer Full Flag. This bit indicates if a new character is in the transmit shadow 
register. 


Receive Buffer Empty Flag. This bit indicates if the last character has been read from the 
receive buffer. 


Modem Control Flag. This bit indicates if the modem control register has been written. 


1 
RXF 


0 
MCF 


TABLE 4. SWITCH PORT (SWP) 


Bit 
Bit 
Bit 
Number 
Name 
Descrlptlon 


6-0 
W 
Switch input. These bits monitor the external switches. 


7 
_ 
Unused. 


TABLE 5. TIMER (TIM) 


Bit 
Bit 
Bit 
Number 
Name 
Descrlptlon 


0 
TFFO 
Timer flip-flop bit. 
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TABLE 6. GENERAL CONTROL (GCR) 


Number 
Name 
Descrlptlon 


7 
CONF 


6 


5 
KDV 


4 
MRDY 


3 


2 


1 
PAGE 


° 


I> 


Configuration Output. This bit controls the state of the MAC configuration. When high, the 
MAC is configured with the serial interface. it is configured with the parallel interlace after 
a reset or when a zero (0) is written to this bit. 


Off Hook Output. When set high, the phone will be placed off hook. 


KDV Output. 


Modem Ready Output. (Note.) 


Active high AA indicator. When high, this bit sets the -AA pin low. (Note.) 


Active high HS indicator. When high, this bit sets the -HS pin low. (Note.) 


Register Page Bit. This bit selects the active register page. When low, the lower 
256 registers are accessed during register operations and when high, the upper 
page is active. 


inverted External Access enable status from -EA pin. This pin reflects the state of the 
-EA pin. 


Note: These bits only have effect if CONF = 1 (i.e., controller is in serial configuration). 


TABLE 7. PROGRAM STATUS BYTE (PSB) 


Bit 
Bit 
Bit 
Number 
Name 


Not Used 


Not Used 
CD\I 


5 


4 


3 


2 


1 
C 


0 


Descrlptlon 


N/A 


N/A 


Global interrupt pending bit - Set upon receipt of interrupt. Cleared when interrupt service 
begins. 


Global interrupt enable bit - When zero, all interrupt are disabled. 


Zero bit - indicates the last arithmetic or compare instruction produced a zero result. 


Negative bit; indicates the last arithmetic or compare instruction produced a negative result. 


Carry bit - Inidcates the state of the arithmetic carry from the most significant bit 
of the ALU for an arithmetic operation or the state of the last bit shifted out of 
the operand for a shift. Arithmetic "borrow" after a subtract is the complement of 
the C flag (i.e., if borrow generated, then C = 0). 


Overflow bit - Indicates the last arithmetic operation produced an overflow. 
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TABLE 8. INSTRUCTION SET TABLE 


Mnemonlc 


ADD/ADDB 


ADD/ADDB 


AND/ANDB 


AND/ANDB 


CMP/CMPB 


DJNZ 
1 
Decrement & JNZ 


EXTB 
Sign Extend Byte 


JBC 
Jump if Bit Clear 


JBS 


JC 


JNC 


JE 


JNE 


JGT 


JGE 


JLE 


JLT 


JV 


JNV 


JH 


JNH 


LCALL 


LD/LDB 


MUL 


NOP 


OR/ORB 


XOR/XORB 


PUSHF 


POPF 


RET 


SHL/SHLB 


SHLL 


SHR/SHRB 


SHRL 


Number 
Of Operands 
Operation 
Bytes‘ 


0 


.. . 
d. 


-tn 


U 
> 


B<---A+B 


D<---A+B 


B <--- A AND B 


D <--- A AND B 


Jump if Bit Set 


Jump if Carry Set 


Jump if No Carr 


Jump if = 


Jump if not = 


Jump if > 


Jump if > = 


Jump if < or = 


Jump if < 


Jump if Overflow 


Jump if No Overflow 


Jump if Higher 


Jump if Not Hig 


Long Cali 


Load 


<--- A 


No Operation 


D <--- D OR A 


D <--- D XOR A 


Push PSB 


Pop PSB 


Shift Left 


Shift Left Lon 


Shift Right 


Shift Right Long 


VL7C225 
VL7C235 
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Time‘ 


11 +N"""' 


15 +N’ 


11 +N" 


15 +N' 
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TABLE 8. INSTRUCTION SET TABLE (CONT.) 


Mnemonlc 


SHRA 


SHRAL 


SJMP 


LJMP 


ST/STB 


SUB/SU BB 


SUB/SUBB 


Number 
Of Operands 
Operation 
Bytes‘ 
Time“ 


Arith Right Shift 
10 + N“" 


Arith Right Long 
15 + N“' 


Short Jump 


U 
OJ 
>> 
-5-5 
(Q 
QOO 


Long Jump 


Store to Memory 
13"“ 


<--- B — 


<--- B — 


‘Add one for immediate words. 
“Add 9 for indirect mode and 2 or 0 for immediate mode, see table. 
'“N is number of bit shifts. 
““lndirect mode 



429 


® VLSI TECHNOLOGY, INC. 
VL7C225 - VL7C235 - VL7C245 


THE MAC AND INTEL 8096 SPEED COMPARISON 
I 
Table 9 is an instfuetie eXe¢Utie time 
are also about twice faster. The other 
8096 with 12 MHz crystal and the MAC 
comparison for the MAC and Intel 8096. 
arithmetic and logic instructions are 
with 19.6608 MHz. The time unit IS 
The bi99eet impfevemet ever 3095 is 
about the same speed. Indirect 
"us". The instructions and operands are 
the 15 bit mtlitipiieatien it is 3-3 I15 
addressing instructions in the MAC is 
all from internal storage. Both the MAC 
versus 6-5 I4$- The lump instructions 
about 20% slower than in the eoee. 
and Intel soee will run slower for 
t 
' 
I 
t .Th 
' 
' 
' 
. 
. 
. 
. 
are wice as er 
eshift instructions 
The following companson ‘storms 
external RAM access 


TABLE 9. MAC AND 8096 SPEED COMPARISON 


Direct i 
_ immediate 
indirect 
Instr. 
Operands 
MAC (us) 
soes (us) 
MAC (us) 
8096(p.s) 
iiiIAc (us) 
8096(tts) 


ADD 
2 
1.02 
1.00 
1.22 
1.25 
1.94 
1.50 


ADD 
3 
1.02 
1.25 
1.22 
1.50 
1.94 
1.75 


ADDB 
2 
1.02 
1.00 
1.02 
1.00 
1.94 
1.50 


ADDB 
3 
1.02 
1.25 
1.02 
1.25 
1.94 
1.75 


AND 
2 
1.02 
0.75 
1.22 
1.25 
1.94 
1.50 


AND 
3 
1.02 
1.00 
1.22 
1.50 
1.94 
1.75 


ANDB 
2 
1.02 
1.00 
1.02 
1.00 
1.94 
1.50 


ANDB 
3 
1.02 
1.25 
1.02 
1.25 
1.94 
1.75 


CMP 
2 
1.02 
1.00 
1.22 
1.25 
1.94 
1.50 


CMPB 
2 
1.02 
1.00 
1.02 
1.00 
1.94 
1.50 


DJNZ 
0.92/1.25 
1.25/2.25 
(No Jump/Jump) 


EXTB 
0.71 
1 .00 


JBC 
1.02/1 .32 
1.25/2.25 


JBS 
1.02/1 .32 
1.25/2.25 


JC 
0.51/0.82 
1.00/2.00 


JE 
0.51/0.82 
1.00/2.00 


JGE 
0.51/0.82 
1.00/2.00 


JGT 
0.51/0.82 
1 .00/2.00 


JH 
0.51/0.82 
1.00/2.00 


JLE 
0.51/0.82 
1.00/2.00 


JLT 
0.51/0.82 
1.00/2.00 


JNC 
0.51/0.82 
1.00/2.00 


JNE 
0.51/0.82 
1.00/2.00 


JNH 
0.51 /0.82 
1.00/2.00 


JNV 
0.51/0.82 
1.00/2.00 


JV 
0.51/0.82 
1.00/2.00 
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TABLE 9. MAC AND 8096 SPEED COMPARISON (CONT.) 


Direct 
Immediate 
Indirect 
8096 (us) 
MAC (us) 
8096(t1s) 
MAC (us) 
8096 (us) 
Instr. 


LCALL 


LD 


LDB 


MUL 
NOP 


OR 
2 
1 
1 
1 
1 
1 


ORB 


PUSHF 


POPF 


RET 


SHL 


SHLB 


SHLL 


SHR 


SHRB 


SHRL 


SHRA 


SHRAL 


SJMP 


ST 
1 
1 


STB 


SUB 


SUBB 


SUB 


SUBB 


XOR 


XORB 


Operands 
MAC (pS) 


1.12 


1.02 


1.02 


3.36 


0.24 


.02 


1.02 


0.51 


0.51 


1.02 


1.12 + 0.10N 


1.12 + 0.10N 


1.53 + 0.10N 


1.12 + 0.10N 


1.12 + 0.10N 


1.53 + 0.10N 


1.02 + 0.10N 


1.53 + 0.10N 


0.71 


.32 


1.32 


1.02 


1.02 


1.02 


1.02 


1.02 


1.02 
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3.25 


1.00 


1.00 


6.50 


1.00 


.00 


1.00 


2.00 


2.25 


3.00 


1.75 + 0.25N 


1.75 + 0.25N 


1.75 + 0.25N 


1.75 + 0.25N 


1.75 + O.25N 


1.75 + 0.25N 


1.75 + 0.25N 


1.75 + 0.25N 


2.00 


.75 


1.75 


1.00 


1.00 


1.25 


1.25 


1.00 


1.00 
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1.22 


1.02 


.22 


1 .02 


1 .22 


1.02 


1 .22 


1 .02 


1 .22 


1.02 


1.25 


1.00 


1.94 


1.94 


(Biggest Improvement) 


.25 
1 .94 


1.00 


1.25 


1.00 


1.50 


1.25 


1.25 


1.00 


1.94 


1.94 


1.94 


1 .94 


1.94 


1.94 


1.94 


1.50 


1.50 


.50 


1.50 


(N = Shift Count) 



1.50 


1.50 


1 .75 


1 .75 


1 .50 
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RAM READ OR WRITE CYCLE TIMING 


Symbol 


tWDS 


tWDH 


tRDH 


Parameter 


[Q 
.-Lofvi-2'-§ 
“3'5 


Address Setup 


Write Data Setup 


Read Data Setup 


—CSRAM Strobe Width 


ALE Strobe Width 


-WR Strobe Width 


-RD Strobe Width 


Delay to -WR/-RD 


Write Data Hold 


Read Data Hold 


RAM READ OR WRITE CYCLE WAVEFORMS 


CYCLE # 


Condltlon 


|o|1|2I3|4I5| 
9 8304 MHZ 
INTERNAL CLK 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 


—CSRAM 


MAO MA14 
ADDRESS 


ADO-AD7 
V 


(WRITE CYCLE) 


(READ CYCLE) 


ADO-AD7 
(READ CYCLE) 


<wRiTE<>Y¢i-Ei 
IWDS 
tWDH 


-WR 
tWW 


(D> 


-RD 


tAW 


ALE 
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EXTERNAL PROGRAM STORAGE READ BUS CYCLE TIMING 
$vm*=°' 
@@@ 
<=°"<""°" 
is 
--E 
‘H 
2I— 
‘W 
I@— 


EXTERNAL PROGRAM STORAGE READ BUS CYCLE WAVEFORMS 


I 
° 
I 
1 
I 
CYCLE # 
9.8304 MHZ 
INTERNAL CLK 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 


MAO-MA14 
X 
>< 


—CSROM 
tW 


IH 


IS 


ADO-AD7 
@ 
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READ CYCLE: PC BUS READ FROM UART REGIS 


Symbol 
Parameter 
Conditlon 


tW 
Enable Strobe Width 


-DIST to Data Delay 


Data Hold 


Address Hold 


5?":5 
:"IE 
6 


:1: 


tn :.i 


-IZ -“é 
2 


G) 


Read Cycle Delay 


READ CYCLE: PC BUS READ FROM UART REGISTER WAVEFORMS (Parallel Configuration Only) 


A0-A2 
— 


—CS 


tAH 
-DIST 


tw 
IR 


tH 
A0-D1 
i 
tD 
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WRITE CYCLE: PC BUS WRITE INTO UART REGISTER TIMING 
SW0‘ 
%@@ 
°°"d"'°" 
‘W 
E!-E 
is 
I-E 
I" 
--E 
‘AH 
E--E 
‘R 
E--E 


WRITE CYCLE: PC BUS WRITE INTO UART REGISTER WAVEFORMS (Parallel Configuration Only) 


A0-A2 
— 


-CS 


-DOST 


tW 
IR 


1.34543 
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MAP AND EERAM BUS INTERFACE WRITE CYCLE TIMING 


Symbol 


tSS 


tAW 


tAS 


tAH 


tD 


tW 


tDH 


%@E 
-E—E 
—-E 
--3 
IIH-E 
—-E 
—E— 
--E 


MAP AND EERAM BUS INTERFACE WRITE CYCLE WAVEFORM 


CYCLE # 
I 
Q 
I 
1 
I 
3 
I 
3 
I 
4 
I 
5 
I 
9.8304 MHz 
INTERNAL CLK 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 


ALE 
tAW 


tSS 
-MCS 
tD 
OR‘ 
—ECS 
tAS 
tAH 


ADO-AD7 
ADDRESS 
‘ 
DATA 
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-WR 
1W 


MAP AND EERAM BUS INTERFACE READ CYCLE TIMING 


Parameter 
Symbol 


tSS 


tAW 


tAS 


tAH 


tD 


tW 


tDS 
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T 


\| 
‘< 


Delay to ALE 


ALE Strobe Width 


Address Setup 


Address Hold 


Delay to -RD 


-RD Strobe Width 


Data Setup 


tDH 
Data Hold 


MAP AND EERAM BUS INTERFACE READ CYCLE WAVEFORMS 


Y 
c CLE # 
I 
0 
I 
1 
I 
2 
I 
3 
I 
4 
I 
5 
I 
9.8304 MHz 
INTERNAL CLK I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 


tAS 
tAH 
tDs 


ADO-AD7 
ADDRESS 
DATA - 


ALE 
- 
tAW 


ISS 
-MCS 
ID 
OR 
—ECS 


-RD 
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ABSOLUTE MAXIMUM RATINGS 


DC CHARACTERISTICS: TA = ooc to +1o<=c, vcc = s v 110%M 
° 
°""°"* 
@:E 
P 
9 


High Level input Voltage for: 


D0-D7, —CS, —DIST, -DOST 


All Other Input Pins 


Low Level Input Voltage for: 
V 


D0-D7, -CS, -DIST, -DOST 


All Other Input Pins 


'L 
—- 
VT+ 
Positive Hysterisis Threshold 
V 
-3-- 


or 
ESET and —RI Input Pins 
"' 
-H- 
VOH 
High Level Output Voltage for: 


D0-D7, -INTO 
0.7VCC + 0.5 
V 


RDY 
-I- 
Aii Other Output Pins 
0.7VCC + 0.5 


VOL 
Low Level Output Voltage for: 
V 


“DY 
-2 °-3"°°-°-5 
AIlOtherOutput Pins 
o.svcc-o.s 


FCLK 
Crystal Frequency 
19.6606 
19.6606 
19.6610 
m 


Symbol 
Parameter 
T 


1“m 


< 


|i"!M 
VCC 
Positive Supply Voltage 


ICC 


VIH 


VIL 
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Ambient Operating 
Stresses above those listed under 
those indicated on the operational 
Temperature 
0°C to +70°C 
"Absolute Maximum Ratings“ may 
sections of this specification IS not 
Stereee Temperemfe __65,,C Ie +15o,,c 
cause permanent damage to_the 
implied and exposure to conditons for 
device. These are stress ratings only. 
extended periods may affect device 
supply Voltage to 
Functional operation of this device at 
reliability. 
Greene Petentiai 
+5 V 
these or any other conditions above 
Applied Voltage 
-0.6 V to VCC +0.6 V 


Power Dissipation 
300 mW 


Condltlon 


VCC = 5 V 


IOH=8mA 


Open Collector 


IOH=2mA 


IOL = 8 mA 


IOL = 8 mA 


IOL = 2 mA 
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FEATURES 


300/1200 BIT-PER-SECOND MODEM 
WITH PIN PROGRAMMABLE RECEIVER GAIN 


- FSK and PSK modulators and 
- High level of integration provides a 
demodulators, high-band and low- 
highly cost effective 300/1200 bit- 
per- second modems 
band filters with compromise ampli- 
tude and group delay equalizers 


- Pin programmable receiver gain 


- Built-in call progress mode and tone 
generators for DTMF V.21 and V.22 
guard tones 


- Bell 212A and CCITT V.21 and V.22 
compatible; V.22 notch filters included 


- Serial control interface 


- Programmable audio output port 


- Analog, digital, and remote digital 
loopback capabilities 


- 24-pin DIP and 28-pin plastic 
leaded chip carrier available 


- Eliminates external components, 
easing design of intelligent modems 


- Usable in North American and 
European modem designs 


- Simple board layout 


- Simple speaker interface for monitor- 
ing phone line 


- Testable signal path 


- Reduced board area 


- Direct replacement for Sierra 
SC11015 


PIN DIAGRAMS 
BLOCK DIAGRAM 


I 
ASYNCI 
, 
- 
PsK 
CRAMBLE 
MODULATOR 
MUX 
VL7C312-PC 
AND 
FSK 
PREFILTER 
MODULATOR 


- - 
MUX 
TCH 
LOW BAND 
__ 
AGND I 
1 
24 I 
TXCKO I 
2 
23 I 


TXCK1 I 
3 
22 I 
TEST1 I 
4 
21 I 
TEST2 I 
5 
20 I 


RXCK I 
6 
19 I 
AUDIOOUT I 
7 
18 I 
GS I 8 
17 I 


RXA1 I 
9 
16 I 


FDUQ I 
10 
15 I 
TXOUT I 
11 
14 I 
VSS I 
12 
13 I 


VCC 
CKOUT 


DGND 
XTAL2 
XTAL1 


N.C. 


_W'R_ 


--RD 
SCK 


D I/O 
TXD 


RXD 


VL7C312-QC 
TXCKO N.C.CKOUT 
TXCK1 AGND vcc 
DGND 
I I I I I I I 
4 
3 
2 
1 2a 27 26 
TEST1 I 
5 
. 
25 
N.c. I 6 
24 
TEST2 I 
7 
RXCK I s 
AUDIO OUT I 9 
cs I 


RXA1 I 
<'58§l38 


TXOUT RXD 
D I/O 


XTAL2 
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DESCRIPTION 
The VL7C312 is a complete 300/1200 
bit-per-second modem enhanced with a 
pin to allow external control of the 
modem receiver's gain. All of the signal 
processing functions needed for a full 
duplex, 300/1200 bit-per-second 212A 
(V.21 or V.22) modem, including both 
FSK and PSK modulators and demodu- 
lators and the high-band and low-band 
filters, are integrated on a single chip. it 
is built using a three-micron CMOS 
double-poiysilicon process that allows 
analog and digital functions to be 
combined on the same chip. This design 
includes capabilities for progress 
monitoring and for generating DTMF as 
well as V.21 or V.22 guard tones. The 
two-to-four wire hybrid is also included, 
simplifying the interface to a DAA. The 
VL7C312 also includes analog loopback 
and remote digital loopback functions for 
self-testing. 
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ORDER INFORMATION 


Part 
Number 
Package 


1112 1314 1516 1713 
K 
VL7C312-PC 
PIBSIIC 
I 
I I I I 
I I 
' 
VL7C312 QC 
Plastic Leaded Chip Carrier (PLCC) 


RXA2 V53 
TXD 
N-Q 
Note: Operating temperature range is 0°C to +70°C. 
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Slgnal 
Descrlptlon 


Transmit Data- Data on this input is modulated by the modem and output on TXOUT pin. 
A logic low is space and a logic high is mark. 


Receive data- The modem demodulates the received carrier and outputs data on this pin. 
A logic low level is space and a logic high level is mark. The controller can force the 
demodulator output to the mark state by sending the code 02. 


Data l/O- Data is shifted in serially when WR is low on rising edges of SCK clock. Data is 
transferred to a latch when WR goes high. Up to seven data bits can be sent. Input 
codes are defined in Table 1. Data is read from the modem serially when RD is low, on 
rising edges of SCK clock. Up to four data bits can be read. Output codes are defined in 
Table 1. 


Strobe output from the controller for shifting data to the modem. 


Strobe output from the controller for serially reading data from the modem. 


Serial shift clock is applied to this pin. It is normally high until data is sent to, or read 
from, the modem. 


Transmit data carrier output. 


Received data carriers. 
_ 


Gain Select- When left open or tied to VSS, the received signal gain compensation is 0 
dB; connected to ground, +2 dB compensation is provided; connected to VCC, the com- 
pensation is +3 dB. 


Output of the hybrid is passed through a programmable attenuator and brought out on 
this pin. Four levels of received signal can be programmed using the control codes listed 
in Table 1. 


Pins for connecting a 7.3728 MHz crystal. An external clock signal can be applied to the 
XTAL1 pin. 


Buffered crystal oscillator signal is output on this pin. lt can drive one LS TTL load. 


Transmitter Clock Output- In high speed, synchronous internal mode, this output supplies 
a 1200 Hz clock to the DTE. 


In high speed, synchronous external mode this pin is an input for receiving a 1200 Hz 
clock from the DTE. 


Receiver Clock Output- In high speed, synchronous, external mode, the modem supplies 
a 1200 Hz clock on this output. 


+ 5 V power supply. 


— 5 V power supply. 


Digital ground. 


Analog ground. 


Used by VLSI for testing. Make no connection to these pins. They must be left floating. 


No Connect- No internal connection is made to this pin and it may be left floating. 


Note: Pin numbers refer to the DIP package. 
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FUNCTIONAL 
DESCRIPTION 
With the addition of a digital controller, 
such as an 8-bit microcontroller and a 
data access arrangement (DAA), a 
highly cost effective, integrated, intelli- 
gent modem can be built. When used 
with the VLSI VL7C213A modem 
controller, which is an 8-bit processor 
combined with a UART, a complete 
Hayes command set compatible modem 
can be configured, taking up a minimum 
of board area. For stand-alone applica- 
tions, the VL7C312 modem, the 
VL7C213 controller, a DAA and an 
RS232-interface are all that are required. 


The VL7C312 is truly a modem on a 
chip. All of the signal processing 
functions needed for a full duplex, 300/ 
1200 bps Bell 212A or CCITT V.21 or 
V.22 modem are integrated on a single 
chip. It operates in a synchronous or 
asynchronous mode and handles 8, 9, 
10, or 11 bit words. 


Like all modems, the VL7C312 needs a 
controller to determine the mode of 
operation, initiate the call to the remote 
modem (either pulse or tone dialing), set 
up the handshaking sequence with the 
remote modem, monitor the call progress 
tones on the line (ringing, busy, answer 
tone, and voice) and switch into the data 
mode. A simple four-line serial data 
interface was designed for the VL7C312, 
enabling it to work with just about any 8- 
bit microcontroller or microprocessor. 
The control lines are: DATA lNPUT/ 
OUTPUT, SHIFT CLOCK, READ and 
WRITE. 


MODEM 
Major sections of the VL7C312 modem 
are a transmitter, a receiver, low-band 
and high-band filters, a two-to-four wire 
hybrid, tone generators and interface 
logic. lt also contains an energy detector 
that's used for detecting the carrier and 
call progress monitoring and an audio 
output for monitoring the line. 


The VL7C312 modem requires plus and 
minus five volts and is available in a 24- 
pin DIP as well as a 28-pin plastic chip 
carrier with “J' leads for surface mount 
applications. The transmitter section 
consists of an async/sync converter, 
scrambler, PSK modulator. and FSK 
modulator. In the high speed mode 
(1200 bps), the PSK modulator is 


connected to the filter. ln the low speed 
mode (300 bps), the FSK modulator is 
connected to the filter. 


TRANSMITTER 
Since data terminals and computers 
may not have the timing accuracy 
required for 1200 bps transmission 
(0.01%), timing correction on the 
incoming data stream must be made. 
The async/sync converter accepts 
asynchronous serial data clocked at a 
rate between 1200 Hz + 1%, -2.5%. lt 
outputs serial data at a fixed rate of 
1200 Hz +/- 0.01% derived from the 
master clock oscillator. To compensate 
for the input and output rate differences, 
a stop bit is either deleted or inserted 
when necessary. If the input data rate is 
slower than the output data rate, a stop 
bit is inserted. If the input data rate is 
faster than the output data rate, a stop 
bit is deleted. The output of the async! 
sync converter is applied to the scram- 
bler. 


The scrambler is a 17-bit shift register 
clocked at 1200 Hz. Outputs from the 
14th and 17th stages are exclusive OR'd 
and further exclusive OR'd with the input 
data. The resultant data is supplied to 
the D input of the shift register. Outputs 
from the first two stages of the shift 
register form the dibit that is applied to 
the PSK modulator. The purpose of the 
scrambler is to randomize data so that 
the energy of the modulated carrier is 
spread over the band of interest. The 
high-band being centered at 2400 Hz or 
the low-band, centered at 1200 Hz. A 
1200 bps modem actually sends two bits 
at a time, called a dibit; dibits are sent at 
600 baud, the actual rate of transmis- 
sion; 600 baud is the optimum rate that 
can be transmitted over the general 
switched telephone network for a full 
duplex FDM (frequency division multi- 
plexing) modem because band limit 
filters in the central office cut off at about 
3000 Hz. 


The dibit applied to the PSK modulator 
produces one of four differential phase 
shifts of the square wave carrier signal 
(1200 Hz or 2400 Hz) at the 600 Hz 
baud rate. The resultant waveform is 
passed through a wave shaping circuit 
that performs a raised cosine function 
(this is the shape factor called out in the 
CCITT V.21 and V.22 specifications,- 


and it also meets the Bell 212A require- 
ment for optimum transmission). The 
wave shaped signal is then passed 
through either the low-band or high- 
band filter depending upon originate or 
answer mode selection. 


For low speed operation the FSK 
modulator is used. It produces one of 
four precision frequencies depending on 
originate or answer mode and the 1 
(mark) or 0 (space) level of the transmit 
data. The frequencies are produced 
from the master clock oscillator using 
programmable dividers. The dividers 
respond quickly to data changes, 
introducing negligible bit jitter while 
maintaining phase coherence. The 
output of the FSK modulator is applied 
to the appropriate filter when the low 
speed mode of the operation is selected. 


The filter section consists of low-band 
(1200 Hz) and high-band (2400 Hz) 
filters, half-channel compromise 
amplitude and group delay equalizers 
for both bands, smoothing filters for both 
bands and multiplexers for routing of the 
transmit and receive signals through the 
appropriate band filters. For CCITT 
V.21 or V.22 applications, a notch filter 
is included that can be programmed for 
either 550 Hz or 1800 Hz. In the call 
progress monitor mode, the low-band 
filter is scaled down by a factor of 2.5 to 
center it over a frequency range of 300 
to 660 Hz. Thus, during call establish- 
ment in the originate mode, call prog- 
ress tones can be monitored through the 
scaled low-band filter and the modem 
answer tone or voice can be monitored 
through the unscaled high-band filter. 


The low-band filter is a 10th order 
switched-capacitor band-pass filter with 
a center frequency of 1200 Hz. In the 
originate mode, this filter is used in the 
transmit direction; in the answer mode it 
is used in the receive direction. When 
analog loopback is used in the originate 
mode, this filter, together with the low- 
band delay equalizer, is in the test loop. 
In the call progress monitoring mode the 
filter response is scaled down by 2.5, 
moving the center frequency to 480 Hz. 


The low-band delay equalizer is a 10th 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the low-band filter and half 
of the compromise line characteristics, 
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producing a flat delay response within 
the pass-band. 


The high-band filter is a 10th order 
switched-capacitor band-pass filter with 
a center frequency of 2400 Hz. In the 
answer mode, this filter is used in the 
transmit direction; in the originate mode, 
it is used in the receive direction. When 
analog loopback is used in the answer 
mode, this filter, together with the high- 
band delay equalizer, will be in the test 
loop. 


The high-band delay equalizer is a 10th 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the high-band filter and half 
of the compromise line characteristics, 
producing a flat delay response within 
the pass-band. The transmit smoothing 
filter is a second order low-pass 
switched-capacitor filter that adds the 
modem transmit signal to the DTMF 
(V.21 or V.22) guard tones. It also 
provides a 3 dB per step programmable 
gain function to set the output level. 


RECEIVER 
The receiver section consists of an 
energy detector, AGC, PSK demodula- 
tor, FSK demodulator, descrambler, and 
sync/async converter. 


The received signal is routed through 
the appropriate band-pass filter and 
applied to both the energy detector and 
AGC circuit. The energy detector is 
based on a peak detection algorithm. It 
provides a detection within 17 to 24 ms. 
It is set to turn on when the signal 
exceeds -43 dBm and turn off when the 
signal falls below -48 dBm. A 2 dB 
minimum hysteresis is provided between 
the turn on and turn off levels. 


The AGC circuit is a programmable gain 
amplifier that covers a range of 28 dB in 
seven steps. The gain is controlled by a 
3 bit up/down counter and the Gain 
Select (GS) pin. See the Signal Descrip- 
tion section for operation. Output of the 
AGC amplifier is rectified and compared 
with two preset levels corresponding to 
desired high and low limits. Outputs of 
the comparators control the up/down 
counter such that the received signal is 
amplified to the desired level. 


The PSK demodulator uses a coherent 
demodulation technique. Output of the 
AGC amplifier is applied to a dual phase 
splitter that produces an in-phase and 


90 degree out of phase component. 
These components are then demodu- 
lated to baseband in a mixer stage 
where individual components are 
multiplied by the recovered carrier. The 
baseband components are low-pass 
filtered to produce I and Q (In-phase and 
Quadrature) channel outputs. The I and 
O channel outputs are rectified, 
summed, and passed through a band- 
pass filter giving a 600 Hz signal. This 
signal is applied to a digital phase lock 
loop (DPLL) to produce a baud rate 
clock. Using the recovered clock signal, 
the I and Q channels are sampled to 
produce the received dibit data. The 
recovered carrier for the demodulator is 
generated by another PLL which is 
controlled by the amplitude of the error 
signal formed by the difference of the I 
and Q outputs. 
' 


The descrambler is similar to the 
scrambler. The received dibit data is 
applied to the D input of a 17 bit shift 
register clocked at 1200 Hz. Outputs 
from the 14th and 17th stages are 
exclusive OR'd and further exclusive 
OR'd with input data to produce received 
data. 


In the asynchronous mode, data from 
the descrambler is applied to the syncl 
async converter to reconstruct the 
originally transmitted asynchronous 
data. For data which had stop bits 
deleted at the transmitter (overspeed 
data), these stop bits are reinserted. 
Underspeed data is passed essentially 
unchanged. 
Output of the sync/async 
converter along with the output of the 
FSK demodulator is applied to a 
multiplexer. The multiplexer selects the 
appropriate output, depending on the 
operating speed, and outputs received 
data on the RXD pin. 


For low speed operation, the FSK 
demodulator is used. The output of the 
AGC amplifier is passed through a zero 
crossing detector and applied to a 
counter that is reset on zero crossings. 
The counter is designed to cycle at a 
rate four times faster than the carrier 
signal. The counter output is low-pass 
filtered and hard limited to generate FSK 
data. 


HYBRID 
The signal on the phone line is the sum 
of the transmit and receive signals. The 
hybrid subtracts the transmitted signal 


from the signal on the line to form the 
received signal. It is important to match 
the hybrid impedance as closely as 
possible to the telephone line to produce 
only the received signal. This matching 
provided by an external resistor con- 
nected between the RXA1 and RXA2 
pins on the VL7C312. The filter section 
provides sufficient attenuation of the out 
of band signals to eliminate leftover 
transmit signals from the received 
signal. The hybrid also acts as a first 
order low-pass antialiasing filter. 


INTERNAL HYBRID 
The VL7C312's internal hybrid is 
intended to simplify the phone line 
interface. In addition, there is a gain 
select feature to compensate for the loss 
in the line coupling transformer used in 
the DAA. By tieing this pin to VSS, 
ground or VDD, compensation levels of 
0, +2 or +3 dB, respectively, are 
provided. 


With a higher loss transformer, some 
degradation in performance at lower 
signal levels will occur. Specifically, the 
bit error rate, when operating at receive 
will be higher. The energy detect on/off 
levels measured at the line will also be 
different from those specified at the chip. 
With a 3 dB loss transformer, for 
example, the energy detect on/off levels 
measured at the line will be in the range 
of -40/-45 dB rather than -43/-48 dB as 
specified at the chip. The +3 dB 
compensation should then be used. 


TONE GENERATOR 
The tone generator section consists of a 
DTMF generator and a V.21 (or V.22) 
guard tone generator. The DTMF 
generator produces all of the tones 
corresponding to digits O through 9 and ' 
and # keys. The V.21 (or V.22) guard 
tone generator produces either 550 Hz 
or 1800 Hz. Selection of either the 550 
Hz or 1800 Hz tone will cascade the 
corresponding notch filter with the low- 
band filter. The tones are selected by 
applying appropriate codes through the 
Data I/O pin. Before a tone can be 
generated, tone mode must be selected. 
Facility is also provided to generate 
single tones corresponding to the 
individual rows or column of the DTMF 
signal. 


AUDIO OUTPUT STAGE 
A programmable attenuator that can 
drive a load impedance of 50 K9 is 
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provided to allow monitoring of the 
received line signal through an external 
speaker. The attenuator is connected to 
the output of the hybrid. Four levels of 
attenuation: no attenuation, 6 dB 
attenuation, 12 dB attenuation and 
squelch are provided through the ALC1, 
ALCO and audio output level control 
codes. Output of the attenuator is 
available on the audio output pin where 
an external audio amplifier (LM386-type) 
can be connected to drive a low 
impedance speaker. The output can 
directly drive a high impedance 
transducer, but the volume level will be 
low. 


CRYSTAL OSCILLATOR 
The VL7C312 includes an inverting 
amplifier between pins 20 and 21 with 
an internal bias resistor to simplify the 
design fo the crystal oscillator. A 
parallel resonant, 7.3728 MHz :l:0.001% 
crystal, designed for a load capacitance 
of 20 pF, should be connected across 
pins 20 and 21. Two capacitors of 
typical values 27 pF from pin 20 to 
digital ground (DGND pin 22) and 47 pF 
from pin 21 to DGND should be con- 
nected. With the recommended crystal, 
Saronix, NYMPH, NYP073-20 and these 
capacitor values, a highly accurate and 
stable crystal oscillator can be designed. 
Since the carrier frequency must be 
within :l:0.01% of the nominal 1200/2400 
Hz, it is important to measure the actual 
crystal oscillator frequency at CKOUT 
(pin 23) and adjust the external capaci- 
tors for a given circuit board layout, if 
necessary. 


VL7C213 AND VL7C214 
CONTROLLERS 
The VL7C213 modem controller, 
implemented in VLSI's two-micron 
CMOS process, was designed specifi- 
cally to handle all of the modem control 
functions, as well as the interface to a 
system bus. Besides including an 8-bit 
microprocessor, 8K by 8 bytes of ROM, 
and 128 by 8 bytes of RAM, it also 
contains the functionality of a VL82C50 
UART, greatly simplifying the interface 
to a parallel system bus, such as used in 
an IBM PC-compatible personal 
computer (PC). In fact, a complete, 
Hayes compatible modem forthe PC 
consists of the VL7C213 controller, the 
VL7C312 modem and the DAA. All of 
the popular communications software 


written for the PC will work with the 
VL7C312/VL7C213 set. 


Another version of the controller, the 
VL7C214, is intended for RS-232 
applications. It contains the same 
processor, memory, and UART as the 
VL7C213 and has the same interface to 
the modem chip. The difference is that 
the UART is turned around so that serial 
data from the RS-232 port is converted 
to parallel data handled by the internal 
processor. Pins are provided for 
connecting the familiar switches and 
indicator lamps found on most stand- 
alone modems, although the switches 
and lamps are not needed for operation. 
All of the switch settings can be done 
through software. 


The VL7C214 provides a standard five 
volt logic level interface. RS-232 drivers 
are required to interface to the port. 
Like the VL7C213, the VL7C214 comes 
preprogrammed with the Hayes "AT" 
command set, and when used with the 
VL7C312 modem, emulates a Hayes- 
type stand-alone modem. The VL7C213 
and VL7C312 emulate a Hayes-type 
IBM PC plug-in card modem. But the 
chip set is by no means limited to 
implementing a Hayes-type smart 
modem. VLSI is in the custom IC 
business and both chips were designed 
with this in mind. For example, only 
about 6K bytes of the VL7C213's ROM 
is used forthe handshaking and smart 
modem code, leaving 2K bytes for 
additional features that a customer may 
specify. Since the controller is ROM 
programmable, any command set can 
be implemented. 


Both the VL7C213 and VL7C214 require 
plus five volts and are available in either 
a 28-pin DIP or a 28-pin plastic chip 
carrier with "J" leads for surface mount 
applications. Besides the four-line 
interface for the VL7C312 modem, the 
VL7C213 controller has an 8-bit data 
port, three address lines, a chip select 
input, an interrupt line, and the DOST 
and DIST control lines found in the 
8250B UART. It also has control lines 
for ring indication, the off-hook relay and 
a data/voice relay; these three lines 
connect to the DAA. 


In the VL7C214, the 8-bit port becomes 
the switch input lines and the address, 
chip select, DIST and DOST lines 


become the six lines for the RS-232 
interface. These six lines are also used 
to drive the LEDs. Internally, all of these 
lines are treated as programmable I/O 
ports under software control. The 
primary difference between the 
VL7C213 and VL7C214 is the ROM 
code. It also contains the same modem 
and DAA interface lines as the 
VL7C213. 


The VL7C213 and VL7C214 are truly 
ASIC controllers. They are designed to 
control a modem or other peripheral that 
operates at a moderately slow data rate 
up to 1200 bits per second. The 
VL7C213 allows a slow peripheral to 
interface to a high speed bus, without 
making the main processor slow down. 


This is done through the UART interface 
and the on-chip registers which look 
somewhat like dual port registers. The 
main processor can write to and read 
from them at will, while the on-chip 
controller can do the same. The 
controller was designed this way 
because most communication software 
has to have unrestrained access to the 
UART registers. To make the VL7C213 
compatible with this software, the 
registers were included. 


The internal processor monitors the 
registers to determine the mode of 
operation. Command mode or data 
mode: at power-up it is automatically put 
in the command mode and it looks for 
instructions. Once carrier is detected, it 
goes into the data mode, and stays 
there until escape sequence is three "+" 
signs (+++) in the default mode, but it 
can be changed in software. 


The processor contains an 8-bit data 
path and can execute 19 instructions 
with five addressing modes: direct, 
indirect, immediate, register direct, and 
register indirect. There is 8K by 8 of 
ROM on-chip for program storage. 


To the system bus, the VL7C213 looks 
and acts just like a VL82C50 UART. All 
of the communications software written 
for this UART will work with the 
VL7C213 and VL7C214. The VLSI chip 
set is a Hayes-type modem in two chips. 


The VL7C31 2 AND 
VL7C21 3./VL7C214 System 
The only external components required 
by the VL7C212A are the 600 Q line 
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matching resistor, a 7.3728 MHz crystal 
(a standard frequency) and a 20 pF 
capacitor from each leg of the crystal to 
ground. If it is desired to drive a 
speaker to monitor the line, an amplifier 
such as the LM386 can be added, but 
the output provided on the VL7C312 
can directly drive a high impedance (50 
kQ) earphone-type transducer. 


The VL7C213 modem controller's clock 
in line is driven by the VL7C312‘s clock 
out line, so only one crystal is needed. 
The VL7C213 interfaces directly to an 
IBM PC bus -- no buffers are required. 
The only external parts may be an eight 
input NAND gate for COM1 and COM2 
decoding inside the PC. 


For tone dialing, the controller sends a 
code to the modem chip which in turn 
puts out the called for DTMF tone on 
the line via the on-chip DTMF genera- 
tor. For pulse dialing, the controller 
pulses the OH (off-hook) relay. Both 
dialing modes work with the built-in call 
progress algorithm so they won't start 
dialing until a dial tone is detected. 
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All modems require a DAA. A DAA 
(data access arrangement) is a piece of 
equipment required by the FCC to 
connect anything to the general 
switched telephone network. It consists 
of an isolation transformer, typically 600 
Q to 600 Q; a relay for disconnecting 
the modem from the line; a ring 
detector, typically an opto-isolator; and 
high voltage surge protectors. The DAA 
has to be FCC registered and this can 
be done by any of many consultants 
and labs around the country. Another 
alternative is to buy a DAA, supplied by 
several manufacturers. 


212A is a Bell specification that calls for 
1200 bit per second, full or half duplex 
data transmission with a fallback mode 
of 300 baud (Bell 103). It is not 1200 
baud; the spec calls for transmission of 
dibits, or 2 bits per baud so the 1200 
bps transmission takes place at 600 
baud. The same is true for V.22; it's 
1200 bps or 600 baud. V.22 does not 
call for a 300 baud fallback; the CCITT 
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standard for 300 baud is V.21. It is not 
a required fallback for V.22, however, it 
is included in the VL7C312A. 


V.22 also calls for guard tones to be 
sent along with the data. In most of 
Europe the tone is 1800 Hz except in 
Sweden where 550 Hz is used. The 
VL7C312A modem has the 550 Hz and 
1800 Hz tone generators built in as well 
as the 550 and 1800 Hz notch filter to 
remove the guard tone when in the 
receive mode. 


All modems require a hybrid. Hybrid is 
a term used to describe a circuit, 
passive or active, that takes the 
separate transmit and receive signals 
and combines them to go over the 
phone line. In the VL7C312A, this is 
done with op amps, but the separate 
signals (TXOUT and RXA2) are also 
brought out so an external hybrid can 
be used, if desired. The combined 
signal comes out on the RXA1 pin and 
a matching resistor (typically 600 Q) is 
connected between RXA1 and RXA2. 
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TABLE 1. DEFINITION OF I/O CODES 
' 
1. Instructions to the modem IC 


VL7C312 


Data on the D I/O pin is shifted into the modem when WR is low, on rising edges of the SCK clock. Data is transferred 
into a latch when WR goes high. (See Figure 2 for write cycle waveforms.) Up to seven data bits (D0--D6) can be sent 
to the device. These bits control the operating modes of the modem as show below: 


D6 
Mode/Function 


Non-Tone Mode: 
Reset (set default values) 
Tone On/Off 
Force Receive Data to Mark Off/On 
TLCO 
Transmit Level Control Bit 0 (default 0) 
TLC1 
Transmit Level Control Bit 1 (default 0) 
TX 
Transmitter On/Off 
ALB 
Analog Loopback On/Off 
CPM 
Call Progress Monitor Mode On/Off 
Connection Indicator (Cl) On/Off 
ALCO 
Audio Output Level Control Bit 0 (default 0) 
ALC1 
Audio Output Level Control Bit 1 (default 0) 
WLSO 
Word Length Select 0 (default 0) 
WLS1 
Word Length Select 1 (default 1) 
Sync/Async 
LS/HS: Low Speed/High Speed 
A/0: 
Answer/Originate 
Transmit Mark On/Off 
Transmit Space On/Off 
Scrambler Disable On/Off 
DLB 
Digital Loopback On/Off 
TXDP 
Transmit Dotting Pattern On/Off 
Locked/Internal 
ExternaVSlave 
2100 Hz Tone On/Off (Must select low speed mode for operation) 
1300 Hz Tone On/Off (Must select low speed mode for operation) 
V.21 On/Off Must select low speed mode for operation 
COCOOOOOOOOOOOOOOOOOOOOOCO 


—L—L_L—L_L_nL¢-Lnnl-L-L—L—L¢-L_A—L—L 


-*-*4-*-*-*-*-*4-‘COOOOQOOOOOOOOCO 


OOOOOOOOOOOOOOOO 


(OGJ\|O3(J1-b(Df\J—*O'T'I|'no(')@><.O(DNO'>UI-§OOf\)—*(D 


'f"||"|'l@(')@>¢OGJNO7U‘I-§(DI\)—*C) 


Tone Mode: 
Dial 0 
Dial 1 
Dial 2 
Dial 3 
Dial 4 
Dial 5 
Dial 6 
Dial 7 
Dial 8 
Dial 9 
Dial ' 
Dial # 
Output 550 Hz and Insert 550 Hz Notch in Low-Band Filter 
Output 1800 Hz and Insert 1800 Hz Notch inLow-Band Fllter 
Row Disable On/Off 
Column Disable On/Off 
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TABLE 1. DEFINITION OF I/O CODES (Cont.) 


WLS1 
WLSO 
Word Length 


8 Bits 
9 Bits 
10 Bits (default) 
11 Bits 
--00 
._A@_AQ 


TLC1 
TLCO 
Transmitter Output Level (dBm) at the Phone Llne 


-A-Loo 
-‘Q-‘Q 
-‘Q-*@ 
o<I> 


-1 2 (default) 
-9 


ALC1 
ALCO 
Audlo Output Level 


Output Off (default) 
12 dB Attenuation 
6 dB Attenuation 
No Attenuation 
--oo 
-L@_A@ 


2. Information from the Modem IC 


Data is read serially from the modem when RD is low, on rising edges of the SCK clock. (See Figure 1 for read cycle 
waveforms.) Up to four data bits (D0--D3) can be read as defined below: 


D0 
Energy Detect 
0 - No Energy 
1 - Energy Present 


In the CPM mode, the energy detector is connected to the output of the high-band filter, if ALB is off, or the scaled low- 
band filter, if ALB is on. 


D1 
Received Data (FSK) 
1 - Mark 
0 - Space 
D2 
Received Data (PSK) 
1 - Mark 
0 - Space 
D3 
Unscrambled Mark 
1 - Detected 
0 - Not Detected 


Notes: 
1. Default values for the operating modes on power-up are those shown to the right of the "/“ unless otherwise specified. 
2. Data is shifted in and out of the modem with LSB first. 
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TABLE 2. AC CHARACTERISTICS 


Condltlons 


‘°‘” 
E--Y 
‘°F‘ 
E--l 
‘PW 
IE:-E 
‘P 
E- 
°"‘Y°Y°'° 
‘° 


FIGURE 1. WAVEFORMS FOR WRITE AND READ CYCLES 
a) Wrlte Cycle 
-0] 
IDW 
l4- IDW 


-WR 


IOKEHEEHEEDIOI 
| 
| 


~=w-I l- 
—~Il-~= 
b) Read Cycle 
—>| 
IDR 
—e' 
IDR 


-RD 


° "° IOXEHEEDIOIOIOIOI 


DTMF GENERATOR CRYSTAL FREQUENCY = 1.312800 MHz ¢o<>/. 
Parameter 


Row 1 


Row 2 


Row 3 


Row 4 


Column 1 


Column2 


Column 3 


Guard Tones 


Nomlnal Fre uenc 
Allowable Error 


O 


OO 
O 
O 


q 
Y 


697 Hz 
:1; 1°/ 


770 Hz 
i 1% 


:l; 1 / 


941 Hz 
i1‘? 


1209 Hz 
iI‘7 


i1°/ 


1477 Hz 
i1°/ 


1:20 Hz 


1800 HZ 
:l: 20 HZ 
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Actual Error 


+ 0.17% 


- 0.26% 


+ 0.16% 


- 0.47% 


- 0.74% 


-0.89% 


- 0.01% 


-1.4 Hz 


+ 7 Hz 


CCITT specification. 
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DTMF GENERATOR (Cont.) 


Second Harmonic Distortion 
VCC = + 5 V 
dB 


Row Output Level 
VSS = - 5 V 
dBm 


Column Output Level 
TI_C0 == 1 
dBm 


550 Hz Guard Tone Levell 
TI_C1 = 1 
dB (Note 2) 


1800 Hz Guard Tone Level 
Measured at TXOUT Pin 
dB (Note 2) 


Note: Guard tone levels are referenced to the TX signal level. When guard tones are added, the TXOUT level is adjusted to 
maintain a constant level on the line. For 1800 Hz, the adjustment is -0.97 dB; for 550 Hz, the adjustment is -1.76 dB, per the 


MODEM TRANSMIT SIGNALS CRYSTAL FREQUENCY = 1.a12aoo MHz :l:0°/> 


Bell 1 oa 
CCITT v 21 
Bell 212A / ccrrr v.22 
Mode 


Mark 
2225 HZ 
Answer 
Space 
2024 4 Hz 
1850 6 Hz 


2226 Hz 
1649 4 Hz 
2400 Hz 


Mark 
1270 HZ 
1269 4 Hz 


Actual 


2400 Hz 


_ 
_ 
. 
980 Hz 
978.34 Hz 
Originate 
1200 Hz 
Space 
. 
. 
1070 HZ 
10704Hz 
1180 HZ 
118153Hz 


Calling Tone 
1301] Hz 
1301.7 Hz 


Answer Tone 


RECEIVER 


Parameter 


Input Signal Range 


Intra - Character Bit Rate 


Carrier Detect 


Carrier Detect Hysterisis 


Carrier Detect Delay 


Carrier Detect Hold 


Carrier Detect Delay 


Carrier Detect Hold 


21 O0 HZ 
2096 9 HZii 
In 
Q 
l_§ 
—B- 
iii 
K 
ii 
iii 
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2096.9 Hz 


Units 


dBm 
,1 
-1’ 


bps 


dBm 


dB 


ms 


ms 


ms 


ms 
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TRANSMITTER 


Input Character Length 
Start Bit + Data Bit + Stop Bit u 


Intra - Character Bit Rate 
At TXD (pin 14) 
1170 


Input Break Sequence Length 
M =. character Length 
2M + 3 


Output Level Tolerance 
- 
""5 
El 
“Pi 
‘I 
<19.°°at 


ABSOLUTE MAXIMUM RATINGS 


Ambient Temperature 
Stresses above those listed under 
Under Bias: 
-10°C to +80°C 
‘Absolute Maximum Ratings“ may 
Storage Temperature 
cause permanent damage to the 


_ 
O 
,, 
device. These are stress ratings only. 
Range’ 
-65 C to +140 C 
Functional Operation of this device at 
Maximum Supply 
these or any other conditions above 
Voltage: 
VCC = +7.0 V, VSS = -7.0 V 


Input Voltage Range: 
Analog Pins; VSS -0.6 V to VCC+0.6 V 
Digital Pins; DGND—0.6 V to VCC+0.6 V 


Maximum Power 
Dissipation @25°C: 
500 mW 


DC CHARACTERISTICS TA= 0°C to 70° C unless otherwise speclfled 


Symbol 
Parameter 
Typ 
I 


VCC 
Positive Supply Voltage 


VSS 


ICC 


ISS 


Negative Supply Voltage 


S§ 


01 
o 
01 


Quiescent Current 


Quiescent Current 


VIH 
High Level Input Voltage 


VIL 
Low Level Input Voltage 


VOH 
High Level Output Voltage 


VOL 
Low Level Output Voltage 


VOM 


VOM 


Maximum Output Signal 
Vp p 


Maximum Output Signal 
Vp p 


M 
VDD 
aximum Input Signal 
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those in the operational sections of this 
specification is not implied and expo- 
sure to absoute maximum rating 
conditions for extended periods may 
effect device reliability. 


Conditions 


VCC-5V 


VSS--5V 


Digital Signal Pins: -no, -wa, Dl/O, 
SCK,TXCK1,TXD 


Digital Signal Pins: -RD, -WR, DI/O, 


SCK, TXCK1, TXD 


@ioi-i. 40 jut (0 s Pins: 0 I/O, CKOUT, 
@ioi-i- soo irA 
axo, TXCKO, RXCK) 


@lOL-160 ),iA (D S Pins: D I/O, CKOUT, 


RXD, TXCKO, RXCK) 


TXOUT, RL-1200 Q (TLC1-1, TLCO-0) 


Audio Out, RL- 50 KO 


RXA1, RXA2 
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300/1200 BIT-PER-SECOND MODEM 
(SINGLE 5-VOLT POWER SUPPLY) 


FEATURES 
DESCRIPTION 
- FSK and PSK modulators and 
- High level of integration provides a 
The VL7C412 IS 8 OOITIPIBIB. 5 V $I"9I° 
demodulators, high-band and low- 
highly cost effective 300/1200 bit- 
SUPPIY. 300/1200 biI'P°"$9°°"d 
band filters with compromise ampli- 
per- second modems 
modem ehawd With 8 PI" I0 a"°W 
tude and group delay equalizers 
_ Eliminates enema‘ com 
"ems 
external control of the receiver's gain. 
po 
' 
All of the signal processing functions 
. ii,r\i€rleb5 Virpzwgzupply with power 
easing design of intelligent modems 
needed ‘or a fun duplex’ 300/1200 bib 


Y p 
9 
- Usable in North American and 
per-second 212A (V.21 or V.22) modem, 
- Pin programmable receiver gain 
European modem designs 
including both FSK and PSK modulators 


- Built-in call progress mode and tone 
- Simple board layout 
and demodulators and the highband 
and low-band filters, are integrated on a 
gxiaonrgor DTMF V21 and V22 
' Simple $P°aI<9FiI1i9l'Ia¢9I0f IT\00ii0f- 
single chip. It is built using a three- 
ine phana Iina 
micron CMOS double-pclysilicon 
° B9" 2128 and CCITT V-21 and V-22 
_ 
- 
process that allows analog and digital 
°°mPalIbI9; V-22 IIOICI1 IIIIBIS I0¢IUd9d 
Testable Slgnal paw 
functions to be combined on the same 
, Sada, Como, ,n,e,,ace 
- Ftadvaad board araa 
chip. This design includes capabilities 


- 
raarammabla audla output part 
SC, 10,6 
lng DTMF as well as v.21 or v.22 guard 
. Ana|og_ digiial, and remote digital 
tones. The two-to-four wire hybrid is 
joopback capabimies 
also included, simplifying the interface to 
a DAA. The VL7C412 also includes 
analog loopback and remote digital 
loopback functions for self-testing. 


- 24-pin DIP and 28-pin plastic 
leaded chip carrier available 


PIN DIAGRAMS 
BLOCK DIAGRAM 


ASYNC 
, 
- 
PSK 
,,,,c,,,,,,,, 
' III‘ 
(lg; 
PREFILTER 
MODULATOR 
VREF I 
1 
24 I 
VCC 
TXCKO 1| 2 
2a I CKOUT 
N E 


TEST1 I 4 
21 I XTAL2 
, 
FILTER 
TEST2 I 5 
20 I 
XTAL1 
TXOUT TRANSMW 
HYBRID 
gag 
RXCK I 6 
19 n PD 
°ETE°T°" 
hliagmg 
Gs 
AUDIOOUT n 7 
1e n -we 
Fl‘-TE"A"° 


nxm -1 9 
1s I SCK 
$ { 
h 
D 
‘d$'° 
RXA2 I 1o 
15 u ovo 
gxg 


~c 
' 
TxouT - 11 
14 - TXD 
Egg 
|-It'll. 
r<=~r> - 


(DX 
12 
13 I 
RXD 
D 


DI/O 
VL7C41 2-QC 
g¢1< 
“;EI4%§T%R 


TXCKO N.C. CKOUT 
-no 
,N"$F, 
2:23: 


| | | | | | | 
TONE AND 
ENERATOR 
TXCKO 
ormr 
4 
s 
2 
1 2a 2126 
GENERATOR 
TXCK‘ 
TEST1 I 
5 
XTAL2 
N.C. I 
6 
. 
XTAL1 
TEST2 " 
7 
P° 
ORDER INFORMATION 
. 
RXCK I 
a 
-WR 
AUDIOOUT - 
9 
no. 
Part 
es - 
-no 
Number 
Package 
RXA1 - 
11 
SCK 
12131415161710 
VL7C412-PC 
PlasticDlP 
' l ' ' ' ' ' 
VL7C412-QC 
Plastic Leaded Chip Carrier (PLCC) 
_ 
RXA2 GND TXD 
N.C. 
_ 
- 
- 
O 
TXOUT RXD D V0 
Note. Operating temperature range IS 0 C to +70°C. 


RXCK 


3 


88'-‘M88338! 
||||||| 


TIU 


9- 


|piiiI1 


ECat? 


$1 
U1-8 $ 
é 
U "I-0 
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SIGNAL DESCRIPTIONS 


Signal 
Pln 
Name 
Number (Note) 


TXD 
14 


RXD 
13 


D I/O 
15 


-WR 


-RD 


SCK 


18. 


17 


16 


TXOUT 
1 1 


RXA1, RXA2 
9, 10 


GS 
8 


AUDIO OUT 
7 


XTAL1, XTAL 
20, 21 


CKOUT 
23 


TXCKO 
2 


TXCK1 
3 


RXCK 
6 


PD 
19 


VCC 


AGND 


24 


12 


DGND 
22 


VREF 
1 


TEST1, 2 
4, S 


VL7C412 


Slgnal 
Descrlptlon 


Transmit Data- Data on this input is modulated by the modem and output on TXOUT pin. 
A logic low is space and a logic high is mark. 


Receive data- The modem demodulates the received carrier and outputs data on this pin. 
A logic low level is space and a logic high level is mark. The controller can force the 
demodulator output to the mark state by sending the code 02. 


Data l/O- Data is shifted in serially when WR is low on rising edges of SCK clock. Data is 
transferred to a latch when WR goes high. Up to seven data bits can be sent. Input 
codes are defined in Table 1. Data is read from the modem serially when RD is low, on 
rising edges of SCK clock. Up to four data bits can be read. Output codes are defined in 
Table 1. 


Strobe output from the controller for shifting data to the modem. 


Strobe output from the controller for serially reading data from the modem. 


Serial shift clock is applied to this pin. It is normally high until data is sent to, or read 
from, the modem. 


Transmit data carrier output. 


Received data carriers. 


Gain Select- When left open or tied to ground, the received signal gain compensation is 
0 dB; connected to VREF, +2 dB compensation is provided; connected to VCC, the com- 
pensation is +3 dB. 


Output of the hybrid is passed through a programmable attenuator and brought out on 
this pin. Four levels of received signal can be programmed using the control codes listed 
in Table 1. 


Pins for connecting a 7.3728 MHz crystal. An external clock signal can be applied to the 
XTAL1 pin. 


Buffered crystal oscillator signal is output on this pin. It can drive one LS TTL load. 


Transmitter Clock Output- In high speed, synchronous internal mode, this output supplies 
a 1200 Hz clock to the DTE. 


In high speed, synchronous external mode this pin is an input for receiving "a 1200 Hz 
clock from the DTE. 


Receiver Clock Output- In high speed, synchronous, external mode, the modem supplies 
a 1200 Hz clock on this output. 


Power Down- When this input is high, the device will be powered down, but the oscillator 
will keep running. When the pin is low, the device will go into normal power mode. 


+ 5 V power supply. 


Analog Ground- This ground line should be routed separately, and connected to a central 
grounding point with the digital ground (DGND) as close to the power supply as possible. 


Digital ground. 


Voltage Reference- This output is a mid-supply reference, generated internally, that is 
approximately VCC+ 2 in value. It is used as a reference point for the line transformer. 
VREF should be bypassed to AGND using a 50 ).iF electrolytic capacitor and a 0.1 pF 
ceramic capacitor in parallel. 


Used by VLSI for testing. Make no connection to these pins. They must be left floating. 


Note: Pin numbers refer to the DIP package. 
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FUNCTIONAL 
DESCRIPTION 
With the addition of a digital controller, 
such as an 8-bit microcontroller and a 
data access arrangement (DAA), a 
highly cost effective, integrated, intelli- 
gent modem can be built. When used 
with the VLSI VL7C213A modem 
controller, which is an 8-bit processor 
combined with a UART, a complete 
Hayes command set compatible modem 
can be configured, taking up a minimum 
of board area. For stand-alone applica- 
tions, the VL7C412 modem, the 
VL7C213 controller, a DAA and an 
RS232-interface are all that are required. 


The VL7C412 is a modem on a chip. All 
of the signal processing functions 
needed for a full duplex, 300/1200 bps 
Bell 212A or CCITT V.21 or V.22 modem 
are integrated on a single chip. It 
operates in a synchronous or asynchro- 
nous mode and handles 8, 9, 10, or 11 
bit words. 


Like all modems, the VL7C412 needs a 
controller to determine the mode of 
operation, initiate the call to the remote 
modem (either pulse or tone dialing), set 
up the handshaking sequence with the 
remote modem, monitor the call progress 
tones on the line (ringing, busy, answer 
tone, and voice) and switch into the data 
mode. A simple four-line serial data 
interface was designed for the VL7C412, 
enabling it to work with just about any 8- 
bit microcontroller or microprocessor. 
The control lines are: DATA INPUT! 
OUTPUT, SHIFT CLOCK, READ and 
WRITE. 


MODEM 
Major sections of the VL7C412 modem 
are a transmitter, a receiver, low-band 
and high-band filters, a two-to-four wire 
hybrid, tone generators and interface 
logic. It also contains an energy detector 
that's used for detecting the carrier and 
call progress monitoring and an audio 
output for monitoring the line. 


The VL7C212A modem requires only 
plus five volts, and is available in a 24- 
pin DIP as well as a 28-pin plastic chip 
carrier with "J" leads for surface mount 
applications. The transmitter section 
consists of an async/sync converter, 
scrambler, PSK modulator. and FSK 
modulator. In the high speed mode 
(1200 bps), the PSK modulator is 


connected to the filter. In the low speed 
mode (300 bps), the FSK modulator is 
connected to the filter. 


TRANSMITTER 
Since data terminals and computers 
may not have the timing accuracy 
required for 1200 bps transmission 
(0.01%), timing correction on the 
incoming data stream must be made. 
The async/sync converter accepts 
asynchronous serial data clocked at a 
rate between 1200 Hz + 1%, -2.5%. It 
outputs serial data at a fixed rate of 
1200 Hz +/- 0.01% derived from the 
master clock oscillator. To compensate 
for the input and output rate differences, 
a stop bit is either deleted or inserted 
when necessary. If the input data rate is 
slower than the output data rate, a stop 
bit is inserted. If the input data rate is 
faster than the output data rate, a stop 
bit is deleted. The output of the async! 
sync converter is applied to the scram- 
bler. 


The scrambler is a 17-bit shift register 
clocked at 1200 Hz. Outputs from the 
14th and 17th stages are exclusive OR'd 
and further exclusive OR'd with the input 
data. The resultant data is supplied to 
the D input of the shift register. Outputs 
from the first two stages of the shift 
register form the dibit that is applied to 
the PSK modulator. The purpose of the 
scrambler is to randomize data so that 
the energy of the modulated carrier is 
spread over the band of interest. The 
high-band being centered at 2400 Hz or 
the low-band, centered at 1200 Hz. A 
1200 bps modem actually sends two bits 
at a time, called a dibit; dibits are sent at 
600 baud, the actual rate of transmis- 
sion; 600 baud is the optimum rate that 
can be transmitted over the general 
switched telephone network for a full 
duplex FDM (frequency division multi- 
plexing) modem because band limit 
filters in the central office cutoff at about 
3000 Hz. 


The dibit applied to the PSK modulator 
produces one of four differential phase 
shifts of the square wave carrier signal 
(1200 Hz or 2400 Hz) at the 600 Hz 
baud rate. The resultant waveform is 
passed through a wave shaping circuit 
that performs a raised cosine function 
(this is the shape factor called out in the 
CCITT V.21 and V.22 specifications, 
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and it also meets the Bell 212A require- 
ment for optimum transmission). The 
wave shaped signal is then passed 
through either the low-band or high- 
band filter depending upon originate or 
answer mode selection. 


For low speed operation the FSK 
modulator is used. It produces one of 
four precision frequencies depending on 
originate or answer mode and the 1 
(mark) or 0 (space) level of the transmit 
data. The frequencies are produced 
from the master clock oscillator using 
programmable dividers. The dividers 
respond quickly to data changes, 
introducing negligible bit jitter while 
maintaining phase coherence. The 
output of the FSK modulator is applied 
to the appropriate filter when the low 
speed mode of the operation is selected. 


The filter section consists of low-band 
(1200 Hz) and high-band (2400 Hz) 
filters, half-channel compromise 
amplitude and group delay equalizers 
for both bands, smoothing filters for both 
bands and multiplexers for routing of the 
transmit and receive signals through the 
appropriate band filters. For CCITT 
V.21 or V.22 applications, a notch filter 
is included that can be programmed for 
either 550 Hz or 1800 Hz. In the call 
progress monitor mode, the low-band 
filter is scaled down by a factor of 2.5 to 
center it over a frequency range of 300 
to 660 Hz. Thus, during call establish- 
ment in the originate mode, call prog- 
ress tones can be monitored through the 
scaled low-band filter and the modem 
answer tone or voice can be monitored 
through the unscaled high-band filter. 


The low-band filter is a 10th order 
switched-capacitor band-pass filter with 
a center frequency of 1200 Hz. In the 
originate mode, this filter is used in the 
transmit direction; in the answer mode it 
is used in the receive direction. When 
analog loopback is used in the originate 
mode, this filter, together with the low- 
band delay equalizer, is in the test loop. 
In the call progress monitoring mode the 
filter response is scaled down by 2.5, 
moving the center frequency to 480 Hz. 


The low-band delay equalizer is a 10th 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the low-band filter and half of 
the compromise line characteristics, 
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producing a flat delay response within 
the pass-band. 


The high-band filter is a 10th order 
switched-capacitor band-pass filter with 
a center frequency of 2400 Hz. In the 
answer mode, this filter is used in the 
transmit direction; in the originate mode, 
it is used in the receive direction. When 
analog loopback is used in the answer 
mode, this filter, together with the high- 
band delay equalizer, will be in the test 
loop. 


The high-band delay equalizer is a 10th 
order switched-capacitor all-pass filter 
that compensates for the group delay 
variation of the high-band filter and half 
of the compromise line characteristics, 
producing a flat delay response within 
the pass-band. The transmit smoothing 
filter is a second order low-pass 
switched-capacitor filter that adds the 
modem transmit signal to the DTMF 
(V.21 or V.22) guard tones. It also 
provides a 3 dB per step programmable 
gain function to set the output level. 


RECEIVER 
The receiver section consists of an 
energy detector, AGC, PSK demodula- 
tor, FSK demodulator, descrambler, and 
sync/async converter. 


The received signal is routed through 
the appropriate band-pass filter and 
applied to both the energy detector and 
AGC circuit. The energy detector is 
based on a peak detection algorithm. It 
provides a detection within 17 to 24 ms. 
It is set to turn on when the signal 
exceeds -43 dBm and turn off when the 
signal falls below -48 dBm. A 2 dB 
minimum hysteresis is provided between 
the turn on and turn off levels. 


The AGC circuit is a programmable gain 
amplifier that covers a range of 28 dB in 
seven steps. The gain is controlled by a 
3 bit up/down counter and the Gain 
Select (GS) pin. See Signal Descriptions 
for operation. Output of the AGC 
amplifier is rectified and compared with 
two preset levels corresponding to 
desired high and low limits. Outputs of 
the comparators control the up/down 
counter such that the received signal is 
amplified to the desired level. 


The PSK demodulator uses a coherent 
demodulation technique. Output of the 
AGC amplifier is applied to a dual phase 
splitter that produces an in-phase and 


90 degree out of phase component. 
These components are then demodu- 
lated to baseband in a mixer stage 
where individual components are 
multiplied by the recovered carrier. The 
baseband components are low-pass 
filtered to produce l and Q (in-phase and 
Quadrature) channel outputs. The I and 
Q channel outputs are rectified, 
summed, and passed through a band- 
pass filter giving a 600 Hz signal. This 
signal is applied to a digital phase lock 
loop (DPLL) to produce a baud rate 
clock. Using the recovered clock signal, 
the l and Q channels are sampled to 
produce the received dibit data. The 
recovered carrier for the demodulator is 
generated by another PLL which is 
controlled by the amplitude of the error 
signal formed by the difference of the I 
and Q outputs. 


The descrambler is similar to the 
scrambler. The received dibit data is 
applied to the D input of a 17 bit shift 
register clocked at 1200 Hz. Outputs 
from the 14th and 17th stages are 
exclusive OR'd and further exclusive 
OR'd with input data to produce received 
data. 


In the asynchronous mode, data from 
the descrambler is applied to the syncl 
async converter to reconstruct the 
originally transmitted asynchronous 
data. For data which had stop bits 
deleted at the transmitter (overspeed 
data), these stop bits are reinserted. 
Underspeed data is passed essentially 
unchanged. 
Output of the sync/async 
converter along with the output of the 
FSK demodulator is applied to a 
multiplexer. The multiplexer selects the 
appropriate output, depending on the 
operating speed, and outputs received 
data on the RXD pin. 


For low speed operation, the FSK 
demodulator is used. The output of the 
AGC amplifier is passed through a zero 
crossing detector and applied to a 
counter that is reset on zero crossings. 
The counter is designed to cycle at a 
rate four times faster than the carrier 
signal. The counter output is low-pass 
filtered and hard limited to generate FSK 
data. 


HYBRID 
The signal on the phone line is the sum 
of the transmit and receive signals. The 
hybrid subtracts the transmitted signal 


from the signal on the line to form the 
received signal. It is important to match 
the hybrid impedance as closely as 
possible to the telephone line to produce 
only the received signal. This matching 
provided by an external resistor con- 
nected between the RXA1 and RXA2 
pins on the VL7C412. The filter section 
provides sufficient attenuation of the out 
of band signals to eliminate leftover 
transmit signals from the received 
signal. The hybrid also acts as a first 
order low-pass antialiasing filter. 


INTERNAL HYBRID 
The VL7C412 internal hybrid is intended 
to simplify the phone line interface. In 
addition, there is a gain select feature to 
compensate for the loss in the line 
coupling transformer used in the DAA. 
By tieing this pin to VSS, ground or 
VDD, compensation levels of 0, +2 or +3 
dB, respectively, are provided. 


With a higher loss transformer, some 
degradation in performance at lower 
signal levels will occur. Specifically, the 
bit error rate, when operating at receive 
will be higher. The energy detect on/off 
levels measured at the line will also be 
different from those specified at the chip. 
With a 3 dB loss transformer, for 
example, the energy detect on/off levels 
measured at the line will be in the range 
of -40/-45 dB rather than -43/-48 dB as 
specified at the chip. The +3 dB 
compensation should then be used. 


TONE GENERATOR 
The tone generator section consists of a 
DTMF generator and a V.21 (or V.22) 
guard tone generator. The DTMF 
generator produces all of the tones 
corresponding to digits 0 through 9 and ' 
and # keys. The V.21 (or V.22) guard 
tone generator produces either 550 Hz 
or 1800 Hz. Selection of either the 550 
Hz or 1800 Hz tone will cascade the 
corresponding notch filter with the low- 
band filter. The tones are selected by 
applying appropriate codes through the 
Data I/O pin. Before a tone can be 
generated, tone mode must be selected. 
Facility is also provided to generate 
single tones corresponding to the 
individual rows or column of the DTMF 
signal. 


AUDIO OUTPUT STAGE 
A programmable attenuator that can 
drive a load impedance of 50 kn is 
provided to allow monitoring of the 
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received line signal through an external 
speaker. The attenuator is connected to 
the output of the hybrid. Four levels of 
attenuation: no attenuation, 6 dB 
attenuation, 12 dB attenuation and 
squelch are provided through the ALC1, 
ALCO and audio output level control 
codes. Output of the attenuator is 
available on the audio output pin where 
an external audio amplifier (LM386-type) 
can be connected to drive a low 
impedance speaker. The output can 
directly drive a high impedance 
transducer, but the volume level will be 
low. 


VL7C213 AND VL7C214 
CONTROLLERS 
The VL7C213 modem controller, 
implemented in VLSl's two-micron 
CMOS process, was designed specifi- 
cally to handle all of the modem control 
functions, as well as the interface to a 
system bus. Besides including an 8-bit 
microprocessor, 8K by 8 bytes of ROM, 
and 128 by 8 bytes of RAM, it also 
contains the functionality of a VL82C50 
UART, greatly simplifying the interface 
to a parallel system bus, such as used in 
an IBM PC-compatible personal 
computer (PC). In fact, a complete, 
Hayes compatible modem forthe PC 
consists of the VL7C213 controller, the 
VL7C412 modem and the DAA. All of 
the popular communications software 
written for the PC will work with the 
VL7C412/VL7C213 set. 


Another version of the controller, the 
VL7C214, is intended for RS-232 
applications. It contains the same 
processor, memory, and UART as the 
VL7C213 and has the same interface to 
the modem chip. The difference is that 
the UART is turned around so that serial 
data from the RS-232 port is converted 
to parallel data handled by the internal 
processor. Pins are provided for 
connecting the familiar switches and 
indicator lamps found on most stand- 
alone modems, although the switches 
and lamps are not needed for operation. 
All of the switch settings can be done 
through software. 


The VL7C214 provides a standard five 
volt logic level interface. RS-232 drivers 
are required to interface to the port. 
Like the VL7C213, the VL7C214 comes 
preprogrammed with the Hayes "AT" 
command set, and when used with the 


VL7C412 modem, emulates a Hayes- 
type stand-alone modem. The VL7C213 
and VL7C412 emulate a" Hayes-type 
IBM PC plug-in card modem. But the 
chip set is by no means limited to 
implementing a Hayes-type smart 
modem. VLSI is in the custom IC 
business and both chips were designed 
with this in mind. For example, only 
about 6K bytes of the VL7C213's ROM 
is used forthe handshaking and smart 
modem code, leaving 2K bytes for 
additional features that a customer may 
specify. Since the controller is ROM 
programmable, any command set, not 
just the Hayes "AT" set, can be imple- 
mented. 


Both the VL7C213 and VL7C214 require 
plus five volts and are available in either 
a 28-pin DIP or a 28-pin plastic chip 
carrier with "J" leads for surface mount 
applications. Besides the four-line 
interface for the VL7C412 modem, the 
VL7C213 controller has an 8-bit data 
port, three address lines, a chip select 
input, an interrupt line, and the DOST 
and DIST control lines found in the 
8250B UART. It also has control lines 
for ring indication, the off-hook relay and 
a data/voice relay; these three lines 
connect to the DAA. 


In the VL7C214, the 8-bit port becomes 
the switch input lines and the address, 
chip select, DIST and DOST lines 
become the six lines for the RS-232 
interface. These six lines are also used 
to drive the LEDs. Internally, all of these 
lines are treated as programmable VO 
ports under software control. The 
primary difference between the 
VL7C213 and VL7C214 is the ROM 
code. It also contains the same modem 
and DAA interface lines as the 
VL7C213. 


The VL7C213 and VL7C214 are truly 
ASIC controllers. They are designed to 
control a modem or other peripheral that 
operates at a moderately slow data rate 
up to 1200 bits per secnnd. The 
VL7C213 allows a slow peripheral to 
interface to a high speed bus, without 
making the main processor slow down. 


This is done through the UART interface 
and the on-chip registers which look 
somewhat like dual port registers. The 
main processor can write to and read 
from them at will, while the on-chip 
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controller can do the same. The 
controller was designed this way 
because most communication software 
has to have unrestrained access to the 
UART registers. To make the VL7C213 
compatible with this software, the 
registers were included. 


The internal processor monitors the 
registers to determine the mode of 
operation. Command mode or data 
mode: at power-up it is automatically put 
in the command mode and it looks for 
instructions. Once carrier is detected, it 
goes into the data mode, and stays 
there until escape sequence is three "+" 
signs (+++) in the default mode, but it 
can be changed in software. 


The actual processor contains an 8-bit 
data path and can execute 19 instruc- 
tions with five different addressing 
modes: direct, indirect, immediate, 
register direct, and register indirect. 
There is 8K by 8 of ROM on-chip for 
program storage. 


To the system bus, the VL7C213 looks 
and acts just like a VL82C50 UART. All 
of the communications software written 
for this UART will work with the 
VL7C213 and VL7C214. The VLSI chip 
set is a Hayes-type modem in two chips. 


CRYSTAL OSCILLATOR 
_ 
The VL7C412 includes an inverting 
amplifier between pins 20 and 21 with 
an internal bias resistor to simplify the 
design fo the crystal oscillator. A 
parallel resonant, 7.3728 MHz i0.001% 
crystal, designed for a load capacitance 
of 20 pF, should be connected across 
pins 20 and 21 . Two capacitors of 
typical values 27 pF from pin 20 to 
digital ground (DGND pin 22) and 47 pF 
from pin 21 to DGND should be con- 
nected. With the recommended crystal, 
Saronix, NYMPH, NYP073-20 and these 
capacitor values, a highly accurate and 
stable crystal oscillator can be designed. 
Since the carrier frequency must be 
within 10.01% of the nominal 1200/2400 
Hz, it is important to measure the actual 
crystal oscillator frequency at CKOUT 
(pin 23) and adjust the external capaci- 
tors for a given circuit board layout, if 
necessary. 


The VL7C412 AND 
VL7C213NL7C214 System 
The only external-components required 
by the VL7C412 are the 600 Q line 
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matching resistor, a 7.3728 MHz crystal 
(a standard frequency) and a 20 pF 
capacitor from each leg of the crystal to 
ground. If it is desired to drive a 
speaker to monitor the line, an amplifier 
like the LM386 can be added, but the 
output provided on the VL7C412 can 
directly drive a high impedance (50 k.Q) 
earphone-type transducer. 


The VL7C213 modem controller's clock 
in line is driven by the VL7C412‘s clock 
out line, so only one crystal is needed. 
The VL7C213 interfaces directly to an 
IBM PC bus -- no buffers are required. 
The only external parts may be an eight 
input NAND gate for COM1 and COM2 
decoding inside the PC. 


For tone dialing, the controller sends a 
code to the modem chip which in turn 
puts out the called for DTMF tone on 
the line via the on-chip DTMF genera- 
tor. For pulse dialing, the controller 
pulses the OH (off-hook) relay. Both 
dialing modes work with the built-in call 
progress algorithm so they wont start 


I 


dialing until a dial tone is detected. 


All modems require a DAA. A DAA 
(data access arrangement) is a piece of 
equipment required by the FCC to 
connect anything to the general 
switched telephone network. It consists 
of an isolation transformer, typically 600 
Q to 600 Q; a relay for disconnecting 
the modem from the line; a ring 
detector, typically an opto-isolator; and 
high voltage surge protectors. The DAA 
has to be FCC registered and this can 
be done by any of many consultants 
and labs around the country. Another 
alternative is to buy a DAA, supplied by 
several manufacturers. 


212A is a Bell specification that calls for 
1200 bit per second, full or half duplex 
data transmission with a fallback mode 
of 300 baud (Bell 103). It is not 1200 
baud; the spec calls for transmission of 
dibits, or 2 bits per baud so the 1200 
bps transmission takes place at 600 
baud. The same is true for V.22; it's 
1200 bps or 600 baud. V.22 does not 
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call for a 300 baud fallback; the CCITT 
standard for 300 baud is V.21. It is not 
a required fallback for V.22, however, it 
is included in the VL7C412. 


V.22 also calls for guard tones to be 
sent along with the data. In most of 
Europe the tone is 1800 Hz except in 
Sweden where 550 Hz is used. The 
VL7C412 modem has the 550 Hz and 
1800 Hz tone generators built in as well 
as the 550 and 1800 Hz notch filter to 
remove the guard tone when in the 
receive mode. 


All modems require a hybrid. Hybrid is 
a term used to describe a circuit, 
passive or active, that takes the 
separate transmit and receive signals 
and combines them to go over the 
phone line. In the VL7C412, this is 
done with op amps, but the separate 
signals (TXOUT and RXA2) are also 
brought out so an external hybrid can 
be used, if desired. The combined 
signal comes out on the RXA1 pin and 
a matching resistor (typically 600 Q) is 
connected between RXA1 and RXA2. 


S 


TABLE 1. DEFINITION OF I/O CODES 


1. Instructions to the modem IC 
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Data on the D I/O pin is shifted into the modem when WR is low, on rising edges of the SCK clock. Data is transferred 
into a latch when WR goes high. (See Figure 2 for write cycle waveforms.) Up to seven data bits (D0--D6) can be sent 
to the device. These bits control the operating modes of the modem as show below: 


D6 
Mode/Function 


Non-Tone Mode: 
Reset (set default values) 
Tone On/Off 
Force Receive Data to Mark Off/On 
TLCO 
Transmit Level Control Bit 0 (default 0) 
TLC1 
Transmit Level Control Bit 1 (default 0) 
TX 
Transmitter On/Off 
ALB 
Analog Loopback On/Off 
CPM 
Call Progress Monitor Mode On/Off 
Connection Indicator (Cl) On/Off 
ALCO 
Audio Output Level Control Bit 0 (default 0) 
ALC1 
Audio Output Level Control Bit 1 (default 0) 
WLSO Word Length Select 0 (default 0) 
WLS1 
Word Length Select 1 (default 1) 
Sync/Async 
LS/HS: Low Speed/High Speed 
A/0: 
Answer/Originate 
Transmit Mark On/Off 
Transmit Space On/Off 
Scrambler Disable On/Off 
DLB 
Digital Loopback On/Off 
TXDP 
Transmit Dotting Pattern On/Off 
Locked/Internal 
External/Slave 
2100 Hz Tone On/Off (Must select low speed mode for operation) 
1300 Hz Tone On/Off (Must select low speed mode for operation) 
V.21 On/Off (Must select low speed mode for operation) 
Power Down. To power up, device must be reset. 
OQOOOOOOOOQOQQOOOQOOQOOOOOO 
-*-*-*-*-*4-*—*—*—*—*OOCOOC)C)C)C)CDCDOC)C)OO 


OOOOCJQOOOOCJOOOOO 


><ooo~io>cn->.c>ro-~o'r1mc'JC>m><ooo\io1o1.>.coio-o 


"I11@f)@>(O®NO'8U‘l-§(D|\)—*C) 


Tone Mode: 
Dial 0 
Dial 1 
Dial 2 
Dial 3 
Dial 4 
Dial 5 
Dial 6 
Dial 7 
Dial 8 
Dial 9 
Dial ' 
Dial # 
Output 550 Hz and Insert 550 Hz Notch in Low-Band Filter 
Output 1800 Hz and Insert 1800 Hz Notch inLow-Band Filter 
Row Disable On/Off 
Column Disable On/Off 
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TABLE 1. DEFINITION OF I/O CODES (Cont.) 


WLS1 
WLSO 
Word Length 


8 Bits 
9 Bits 
10 Bits (default) 
11 Bits 
...i....i.(3Q 
_.Lo_¢o 


TLC1 
TLCO 
Transmitter Output Level (dBm) at the Phone Line 


-14 (default) 
-12 


-l-400 
_AQ_AQ 
..;Q_¢Q 
-10 


ALC1 
Audio Output Level 


Output Off (default) 
12 dB Attenuation 
6 dB Attenuation 
No Attenuation 
_A_A@@ 
-AQJQ 
—*O—*O 


2. Information from the Modem IC 


Data is read serially from the modem when RD is low, on rising edges of the SCK clock. (See Figure 1 for read cycle 
waveforms.) Up to four data bits (D0--D3) can be read as defined below: 


D0 
Energy Detect 
0 - No Energy 
1 - Energy Present 


In the CPM mode, the energy detector is connected to the output of the high-band filter, if ALB is off, or the scaled low- 
band filter, if ALB is on. 


D1 
Received Data (FSK) 
1 - Mark 
0 - Space 
D2 
Received Data (PSK) 
1 - Mark 
0 - Space 
D3 
Unscrambled Mark 
1 - Detected 
0 - Not Detected 


Notes: 
1. Default values for the operating modes on power-up are those shown to the right of the "I" unless otherwise specified. 
2. Data is shifted in and out of the modem with LSB first. 
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DTMF GENERATOR CRYSTAL FREQUENCY = 1.312800 MHz 10% 
Parameter 
Nominal Frequency 


Row 1 


Row 2 


Row 3 


Row 4 


Column 1 


Column2 


Column 3 


Guard Tones 


EN-— 
III:-E 
E— 
°"*Y°Y°'° 
IER 


FIGURE 1. WAVEFORMS FOR WRITE AND READ CYCLES 
e) Write Cycle 
-al 
IDW 
r— IDW 


-we 
‘ 


°'"° IOXEHEEHHHPIOI 


I 
I 


raw-I 
I-— -II-tr 
b) Reed Cycle 
—>| 
ton 
—-cl 
IDR 


-RD 


° "° KORENEEDIOIOIOIOI 


-K “Lriiu"——— 


Allowable Error 


697 HZ 
:t1% 


770 Hz 
i1°/ 


:t1% 


:I:1°/o 


:l:1°/ 


:l:1% 


1477 HZ 
:l;1°/ 


1:20 Hz 


1800 Hz 
;t 20 Hz 
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TABLE 2. AC CHARACTERISTICS 


tDW 


Actual Error 


+ 0.17% 


- 0.26% 


+ 0.16% 


- 0.47% 


- 0.74% 


-0.89% 


- 0.01% 


-1.4 Hz 


+7Hz 
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DTMF GENERATOR (Cont.) 


Parameter 
Condltlons 
Typ 
Units 


O. W 
Second Harmonic Distortion 
VCC = + 5 V 


Row Output Level 
5 
VSS = - 5 V 
dBm 


550 Hz Guard Tone Level 
TLC1 = 1 
dB (Note 2) 


1800 Hz Guard Tone Level 
Measured at TXOUT Pin 
dB (Note 2) 


Note: Guard tone levels are referenced to the TX signal level. When guard tones are added, the TXOUT level is adjusted to 
maintain a constant level on the line. For 1800 Hz, the adjustment is -0.97 dB; for 550 Hz, the adjustment is -1.76 dB, per the 
CCITT specification. 


MODEM TRANSMIT SIGNALS CRYSTAL FREQUENCY = 1.312800 MHz 20% 


Bell 1 03 
CCITT V.21 
Bell 21 2A I CCITT V.22 
Mode 
~ 


Answer 
2400 Hz 
2400 Hz 


Mark 
1270 Hz 
980 Hz 
978 34 Hz 
Originate 
1200 Hz 
Space 
1070 Hz 
1070 4 Hz 


Calling Tone 
1301.7 Hz 
1301.7 Hz 


Answer Tone 
2096 9 Hz 
2096.9 Hz 


RECEIVER 


Parameter 
Condltlons 
T p 
Units 


Input Signal Range 
Al RXA1 (Pln 9) 
dBm 


Intra - Character Bit Rate 
Al RXD I Pl" 13 I 
1170 
bps 


Carrier Detect 
A1 RXA1 I PI" 9) 
dBm 


Carrier Detect Hysterisis 
dB 


Caffjgf Detect D9|ay 
For 103 212A and V 22 
ms 


Carrier Detect Hold 
F°' 103 212A and V 22 
ms 


Carrier Detect Delay 
F°' V 21 mode 
ms 


Carrier Detect Hold 
F°' V 21 m°d9 
ms 
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TRANSMITTER 
Parameter 
Condltlons 
T 
Units 


1+~< -A 
‘O 
aQ.°°8' 


Input Character Length 
Start Bit + Data Bit + Stop Bit 


Intra - Character Bit Rate 
1170 
At TXD (pin 14) 


Input Break Sequence Length 
M = character Length 
2M + 3 


Output Level Tolerance 


bits 


1212 
bps 


ABSOLUTE MAXIMUM RATINGS 


Ambient Temperature 
Stresses above those listed under 
Under Bias: 
-10°C to +80°C 
"Absolute Maximum Ratings" may 
SW96 “maiiatura 
32321"il.'2Z2ZTL'l??2Z§?J{?.‘.§‘Z..1, 
R 
: 
-65°C 
40°C 
.' 
. 
. 
. 
' 
ange 
to +1 
Functional Operation of this device at 
MaXImUm Supply 
these or any other conditions above 
Voltage: 
VCC = +7.0 V 


Input Voltage Range: 
Anal. Pins; AGND -0.6 V to VCC+0.6 V 
Digital Pins; DGND—0.6 V to VCC+0.6 V 


Maximum Power 
Dissipation @25°C: 
500 mW 


DC CHARACTERISTICS TA= 0°C to 70° C unless otherwise specified 


Symbol 
Parameter 
Typ 


VCC 
Positive Supply Voltage 


SSSZ 
1'I 


60 
3 
Quiescent Current 


High Level input Voltage 


Low Level Input Voltage 


VOH 
High Level Output Voltage 


VOL 
Low Level Output Voltage 


VOM 
Maximum Output Signal 
Vp-p 


VOM 
Maximum Output Signal 
Vp-p 


Maximum Input Signal 
Vp p 
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those in the operational sections of this 
specification is not implied and expo- 
sure to absoute maximum rating 
conditions for extended periods may 
effect device reliability. 


Conditions 


VCC =1 5 V 


Digital Signal Pins:-RD, -WR, DI/O, 


SCK,TXCK1,TXD 


Digital Signal Pins:-RD, -WR, DI/O, 


SCK, TXCK1, TXD 


@|0i-i.. 40 “A 
(D S Pins: D I/O, CKOUT, 
@|OH- 500 pA 
RXD, TXCKO, RXCK) 


@ioL-180 p.A (0 s Pins: o I/O, CKOUT, 
RXD, TXCKO, RXCK) 


TXOUT, RL-1200 n (TLC1 -1, TLCO-0) 
Audio Out, RL= 50 kn 


RXA1, RXA2 
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HIGH SPEED PARALLEL BUS MODEM CONTROLLER 
WITH AUTOMATIC MODEM POWER DOWN CONTROL 


FEATURES 
DESCRIPTION 
- 
Direct interface to VL7C412 single- 
The VL7C413 Parallel Bus Modem 
bus (in particular to the bus of the IBM 
chip, single-supply modems 
Controller is specifically designed to 
PC, XT or AT). All of the popular com- 


_ 
- 
control the VL7C412 single-chip, 300/ 
munications software written for the PC 
fig:/Fgfge Hayes AT command Set In 
1200 bit-per-second modem. Built with 
will work with the VL7C413/ 


_ 
0 
an advanced two-micron CMOS 
VL7C412 chip set. In addition to 
° BUIIPI0 UART 
process, the VL7C413 provides a 
including the functionality of the 
, Direct IBM PC bus imeace 
highly cost effective solution for 
VL82C50 UART, the VL7C413 contains 


_ 
_ 
interfacing a modem IC to a system 
an 8-bit microprocessor, 8K by 8 bits of 
° LQRDY PI" I°f U59 °" h'9h'$Peed 
bus. When connected to the 
ROM and 128 by 8 bits oi RAM. 
U 
. 
. . 
Ses 
VL7C412’ wnh the addmon of a data 
The VL7C413 automatically controls the 
' CQITIPIBIB Inlelllgeni modem In iW° 19$ 
access arrangement IDAAI’ the 
power up/down feature of the VL7C412 


_ 
_ 
_ 
VL7C413 implements a Hayes-type 
. 
. 
. 
° C°mpaI'bI° Wm‘ '"dusI'Y'SIanda'd 
smart modem for board-level, integral- 
to mamtam lowest possmle System 
$°IIWa'° 
modem applications. Because the 
power Consumpom 
. Automatic power up/down control or 
VL7C413 fully emulates the functional- 
For specific high-volume applications. 
VL7C412 
ity of the VL82C50 UART and includes 
the ccntrcl program can be modified by 


_ 
data bus transceivers, it can be directly 
VLSI I0 include addilitmal wmmarid 
Replacement Io’ S'e"a SC1 1037 
interfaced to a computer's parallel data 
IUO¢Ii0ft$- 


PIN DIAGRAMS 
BLOCK 
DIAGRAM 
VL7C413 
_DOST 
-cost 
1 
28 I vcc 
—DIST 
UART 
-DIST I 2 
27 I -cs 
-cs --—> 
'°F*°Y 
3 
26 ' A2 
A0-A2 
BAUD RATE 
TRANS 
KDV 4 
25 ' A‘ 
IORDY 
INTIE/RTJACE 
TXD 
—R| 
5 
24 " A0 
- 
INT com 
nova 
nxo 
OH I 6 
23 _ M 
oo 01 
REGISTERS 


CLK 
7 
22 D7 


"-‘$3 3 
5% 3? 
“‘2Eéi€i‘éL°“ 
““2E§.%ié2°‘- 
SCK I10 
19 I D4 
DVO 
11 
18 I 
D3 
|N"|' 
TXD 
12 
17 D2 
RXD 
13 
16 I 
D1 
GND '14 
15 I 
DO 
ROM BLOCK 
PC/SUBROUTINE 
IORDY “DOST 
‘C5 
REGISTER 
STACK 
-DIST 
vcc 
A2 
I I I 
28 27 26 
ROM 
_m 
5 
2s A1 
8KX8 
OH 
6 
24/to 
CLK 
7 
23lNT 


_wR I 
8 
TOP VIEW 
22 I 07 
INSTRUCTION 
4,0 I 
9 
21 I we 
W 
REGISTER 
20 I os 
SCK10 


DVO I 1' 12 
13 
14 
15 
16 
11 1819 D4 
ACQUMULATQR 
8 
I I - . - I I 
TIMER 
CONTROL PLA 


TXD 
GND 
01 
03 


RXD 
00 
D2 


ll 
I'll| 
i-,||il 
Illl 


XI2I I I 


RAM 
oRoER inaonintnon 
-RD 
Part 
-WR 
Number 
Package 
DVO 
VL7C413-PC 
Plastic DIP 
VL7C413-QC 
Plastic Leaded Chip Carrier (PLCC) 
KDV 
OH 
_Rl 
Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL 
DESCRIPTIONS 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


-DOST 


-DIST 


IORDY 


KDV 


—Rl 


OH 


CLK 


-WR 


-RD 


SCK 


DI/0 


The CPU can write data or control words into a selected register of the VL7C413 when 
-DOST is low and the chip is selected. Data is latched on the rising edge of the signal. 


The CPU can read data or status information from a selected register of the VL7C413 
when -DIST is low and the chip is selected. 


This open-drain output will go low upon a write or read operation, and remain low until 
internal data setup and hold times have been satisfied. 


This output controls the operation of the data/voice relay. When low, the data/voice relay 
is off and the phone line is connected to the phone set. During a data call, the VL7C413 
makes this output high to operate the data/voice relay, disconnecting the phone set from 
the phone line. It may also be used to drive a relay for multi-line phone applications to 
close the A and A1 leads. 


The output of the ring detector in the DAA is connected to this input. A low level on this 
input indicates the "On" duration of the ring cycle. This is a Schmitt-trigger input, 
allowing for slow rising and falling signals on this pin. 


This output controls the operation of the hookswitch relay in the DAA. During a data call, 
this output is high. It operates the hookswitch relay which causes the phone line to be 
seized. During rotary dialing, the VL7C413 pulses this output at a rate of 10 pulses per 
second with appropriate Mark/Space ratio depending on 212A or V.-22 mode. 


A 7.3728 MHz clock signal must be connected to this input. Normally, the CKOUT pin of 
the VL7C412 modem is connected to this pin. All internal timing is derived from this 
clock. This clock must be adjusted to within 0.01%. 


This pin is used to initiate writing of data to the VL7C412 modem. On power{i§p, it is an 
input for a brief time in which the VL7C413 reads the carrier status switch connected to 
this pin. 
If the switch is closed to ground through an 18 KQ resistor, the VL7C413 sets 
the Received Line Signal Detect (RLSD) Bit in the Modem Status Register. If the switch 
is open, the VL7C413 resets this bit and writes the actual status of the carrier detector 
during a data call. 
If no switch is used, an internal pull-up sets the status during power- 
up to the default state (pull-up to VCC) which is to follow the remote modem's carrier. 


This pin is used to initiate reading of data from the VL7C412 modem. On power-up, this 
pin is an input for a brief time in which the VL7C413 reads the DTR status switch con- 
nected to this pin. 
If this switch is open, the VL7C413 reacts to the status of the DTR bit 
in the UART Modem Control Register. If the switch is closed to ground through 18 kQ, 
the VL7C413 ignores the state of the DTR bit. When the switch is open, writing a zero to 
the DTR bit in the Modem Control Register forces the VL7C413 into the command state 
and when on-line, causes it to hang up. If no switch is used, an internal pull-upto VCC 
sets the status during power-up to the default state (to follow the DTR status). 


The VL7C413 supplies a shift clock on this pin to the VL7C412 modem for reading or 
writingdata. On power-up, this pin is an input for a brief time in which the VL7C413 
reads the Bell/CCITT select switch connected to this pin. 
If this switch is open, Bell 
protocol is selected. If this switch is closed to ground through18 kQ, CCITT V.22 
protocol is selected. If no switch is used, an internal pull-up sets the status during 
power-up to the default state (212A mode). 


The VL7C413 shifts data serially out of this pin to VL7C412 during a write operation and 
shifts data serially into this pin during a read operation from the VL7C412. On power-up 
this pin is an input for a brief time in which the VL7C413 reads the Make/Break ratio 
select switch connected to this pin for selecting the pulse dialing standard. With the 
switch open, the Bell standard 39% Make, 61% Break is selected. With the switch 
closed to ground through 18 KQ, the CCITT standard 33% Make, 67% Break is selected. 
If no switch is used, an internal pull-up sets the status during power-up to the default 
state (Bell standard). 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


TXD 


RXD 


GND 


DO-D7 


INT 


A0-A2 


—CS 


VCC 


12 


13 


14 


15-22 


23 


24-26 


27 


28 


This pin is a serial output pin. During a data call, after the connection is established, the 
VL7C413 convens parallel data received from the computer bus and outputs it in a 
serial, asynchronous format to the VL7C412 modem for modulation. At all other times 
the VL7C413 holds this output in the Mark (high) condition. 


Demodulated data from the VL7C412 modem is received on this pin during a data call. 
A high level is considered Mark and a low level is Space. The VL7C413 convens the 
serial data into a parallel data byte and stores it in the Receiver Buffer Register (RBR). 
The Data Ready bit in the Line Status Register (LSR) is then set, and an appropriate 
interrupt identification code is written in the Interrupt Identification Register (IIR) to signal 
to the computer, the reception of a new data byte. 


Ground reference (O V). 


This is the 8 bit data bus comprising of three-state input/output lines. This bus provides 
bidirectional communication between the VL7C413 and the CPU. Data control words 
and status information are transferred via the D0 - D7 data bus. 


This output goes high whenever any one of the following interrupt types has an active 
condition and is enabled via the IER: Receiver Line Status flag, Received Data Avail- 
able, Transmitter Holding Register Empty, and Modem Status. lt is reset low upon the 
appropriate interrupt servicing. The INT pin is forced to a high impedence state when 
the OUT2 bit of the Modem Control Regiser (MCR) is low (power on state). 


These three address inputs are used during read or write operation to select a UART 
register in the VL7C413 as shown in Table 1. The Divisor Latch Access Bit (DLAB) must 
be set high by the system software to access the bit rate divisor latches as shown in 
Table 2. 


The VL7C413 is selected when this input is low. When high, the VL7C413 forces the 
Data bus lines into a high impedance state. 


Positive supply (+5 V). 


TABLE 1. VL7C413 UART REGISTERS 
mmm@ 


O 
0 
0 
O 


0 


0 


X 


X 


X 


X 


X 


X 


1 
O 


1 
0 
O 


0 


O 


O 


O 


0 


RBR 


THR 


IER 


IIR 


LCR 


MCR 


LSR 


MSR 


STR 


DLL 


DLM 


Receiver Buffer Register (read only) 


Transmitter Holding Register (write only) 


Interrupt Enable Register 


Interrupt Identification R_egister (read only) 


Line Control Register 


Modem Control Register 


Line Status Register 


Modem Status (read only) Register 


Speed 


Divisor Latch (LSB) (write only) 


Divisor Latch (MSB) (write only) 


X = “Don't Care” 
0 = Logic Low 
1 = Logic High 
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FIGURE 1 . UART BLOCK DIAGRAM 
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VL7 


' 
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TABLE 2. VL7C413 UART REGISTER FUNCTION SUMMARY 


Reglster 
Reglster Blt Number 
'“"°"‘°"'° 
Blt 0 
Blt 1 
Blt 2 
Blt 3 
Blt 4 
Blt s 
Blt 6 
Blt 1 


RBR 
Data 


THR 
Data 
Data 


IER 


IIR 


LCR 


MCR 


LSR 


MSR 


DLM 


DLL 


STR 


Receive 
Data 


Interrupt 
Enable 


0 If 
Interrupt 
Pending 


0 - 7 Bit 
Data 


1 - 8 Bit 
Data 


Data 
Terminal 
Ready 


THRE 
Receive 
Modem 
Interrupt 
Line 
Status 
Available 
Enable 
Status 
Interrupt 
Interrupt 
Enable 


O 
C) 


Enable 


Interrupt 
Interrupt 
ID Bit 0 
ID Bit 1 


0 - 1 Stop 
1 - Parity 
1 - Even 
1 = Stick 
1 - Set 
DLAB 
Bit 
Enable 
Parity 
Parity 
Break 
1=2Smp 
Bits 


Data 
Overrun 
Parity 
Framing 
Break 
THRE 
TSRE 
Ready 
Error 
rro 
rr 


0 


0 


I 


i 


0 


Request 
OUT1 
OUT2 
No 
0 
to Send 
0 - INT 
Function 
Output 
to HI-Z 


E 
r 
E or 
Interrupt 


Trailing 
De ta 
1(CTS) 
1 
DSR) 
RING 
RLSD 
Edge Ring 
RLSD 


Data 


Data 


Data 
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TABLE 3 
VL7C413 SOFTWARE REGISTERS 


Reglster 
Range/Unlts 


Ring to answer telephone 


Descrlptlon 


on 


Number of rings 


O 127 ASCII 
Escape code character 


O 127 ASCII 
Character recognized as carriage return 


O 127 ASCII 
Character recognized as line feedback 


O 32 127 ASCII 
Character recognized as back space 


Wait time for dial tone 


1 255 sec 
Wait time for carrier 


Pause time (caused by comma) 


1 255 1/10 sec 
Carrier detect response time 


1 255 1/10 sec 
Delay between loss of carrier and hang up 


.0 
... 
__‘ 
IC 
P 
-P 


50 255 millisec 
Duration and spacing of Touch Tones 


20 255 1/50 sec 
Escape code guard time 


bit mapped 
UART status register 


bit mapped 
Option register 


bit mapped 
Flag register 


Test modes 
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Default 


13 (CR) 


10 (LF) 


8 (BS) 


N 


TABLE 4 COMMAND SUMMARY 


VLSI TECHNOLOGY INC 
VL7C41 3 


PREFIX REPEAT AND ESCAPE COMMANDS 


Command 
Descrlptlon (Notes 1 8- 2) 


AT 


Al 


Attention prefix precedes all command lines except + + + (escape) and A/(repeat) commands 


Repeat last command line (Al is not followed by carriage return) 


+ + + 
Escape code 
go from on line state to command state (one second pause before and after escape 
code entry, , + + + is not followed by carriage return) 


DIALING COMMANDS 


Notes 
Command 
Command 
Descrlptlon ( 


D 


P 


T 


1 8- 2) 
Descrlptlon (Notes 1 8- 2) 


Wait for 1/8 second 


Wait for silence 


h Tone 
Wait for second dial tone 


Return to command state after dialing 


Reverse mode (to call originate only modem) 


OTHER COMMANDS 


Notes 
Comma 
Commands 


A 


e/so 


e1 
c/co 


c1 


E/E0 


E1 


F/F0 


F1 


I-I/H0 


H1 


H2 


VIC 


I1 


I2 


UL1 


L2 


Descrlptlon ( 
1 8- 2) 
Descrlptlon (Notes 1 8- 2) 


swer call 


CCITT 


out waiting 


22 mode 


ll 103 and 212A mode 


for ring 
Speaker on until carrier detected 


Speaker always on 


Go to on line state 


Transmit 
Remote digital loopback off‘ 


Remote digital loopback request 
Carrier on 


R-==~=~i~=od@sd=spiaved 
— 
Result codes not displayed 


Requests current value of register r 


Full duplex 
S = n 
Sets register r to value of n 


On hook (hang up) 
Digit result codes 


Off hook, line and auxilia 
Word result codes‘ 


Off hook, line relay only 
X/X 
Compatible with Hayes type 300 modems‘ 


Request product ID code (130) 
Result code CONNECT 1200 enabled 


Firmware revision number 
Enables dial tone detection 


Test internal memor 
Enables bus 
SI nal detection 
Y 


Low speaker volume 
Enables dial tone and bus 
SI nal detection 


Medium speaker volume 
Y/Y0 
Lon 
s ace disconnect disabled‘ 


Hi h s eaker volume 
Lon 
s ace disconnect enabled 
L3 
g 
p 


M/M0 
Speaker always off 
Softw 
et 
I 
f 
It 
ttin s 
Notes 
1. Default modes are indicated by 
2. Commands entered with null parameters assume O 
X is the same as X0 
3. When the ATB command IS used in the answer mode, the VL7C412 is placed in either the V 21 or the V 22 mode, depend 


are res 
restoresalde au 
se 
g 


ing on the response from the remote modem 
In the originate mode, the VL7C413 will sense if the baud rate IS set at 300 or 
1200 bits per sec 
will adju 
e VL7C412 accordingly 
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TABLE 5. RESULT CODES 


Dlglt Code 


0 


1 
Connect 


2 


3 
No Carrier 


4 


5 
Connect 1200 


6 
No Dialtone 


7 
Busy 


8 
No Answer 


Word Code 


7i 
Command executed 


Connected at 300 or 1200 bps 


Ringing signal detected (Note) 


Carrier signal not detected or lost 


Illegal command 
Error in command line 


Descrlptlon 


Connected at 300 bps, if result of X1, X2, X3, or X4 command 


Command line exceeds buffer (40 characters, including punctuation) 
Invalid character format at 1200 bps 


Results from X2 or X4 commands only 


Results from X3 or X4 commands only 


Results from @ command only 


Connected at 1200 bps. Results from X1, X2, X3, or X4 commands only 


Dialtone not detected and subsequent commands not processed 


Busy signal detected and subsequent commands not processed 


Silence not detected and subsequent commands not processed 


Note: When the VL7C413 detects a ringing on the telephone line, it sends a RING result code. However, the VL7C413 
will answer the call only if it is in auto-answer mode or is given an A command. 


TABLE 6. RESET CONTROL OF REGISTERS AND PINOUT SIGNALS 


Reglster/Slgnal 


Receiver Buffer Register 


Transmitter Holding Register 


Interrupt Enable Register 


Interrupt Identification Register 


Line Control Register 


MODEM Control Register 


Line Status Register 


Modem Status Register 


- Divisor Latch (high order bits) 


TXD 


INT 



Reset Control 


First word received 


Writing into the Transmitter Holding Register 


ower on reset 


Power on reset 


Writing into the LCR 


Power on reset 


Power on reset 


Power on reset 


Power on reset 


Master reset 


Power on reset 
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Reset State 


Data 


Data 


All bits low 


Bit 0 high; 
bits 1-7 low 


Data 


All bits low 


Bits 0-4, 7 low; 
bits 5-6 high 


Bits 0-3, 6-7 low; 
bits 4-5 high 


1200 bps 


High 


Low (high impedence) 
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UART 
REGISTERS 
Llne Control 
Registers 
This register controls the format of the 
asynchronous data communications. 


Bit 0 and 1: Bit 1 is always high. Bit 0 
specifies the number of bits in each 
transmitted or received serial character. 
The encoding of bit 0 is as follows: 


Bit 1 
Bit O 
Word Length 


1 
O 
7 Bits 


1 
1 
8 Bits 


Bit 2: This bit specifies the number of 
Stop bits in each transmitted or re- 
ceived serial character. If bit 2 is a logic 
0, one Stop bit is generated or checked 
in the transmit or receive data, respec- 
tively. If bit 2 is a logic 1, when 7-bit 
word length with no Parity is selected, 
two Stop bits are generated or checked. 


Bit 3: This bit is the Parity Enable bit. 
When bit 0 is a logic 0 and bit 3 is a 
logic 1, a Parity bit is generated 
(transmit data) or checked (receive 
data) between the last data word bit and 
the Stop bit of the serial data. (The 
Parity bit is used to produce an even or 
odd number of 1s when the data word 
bits and the Parity bit are summed.) 


Bit 4: This bit is the Even Parity Select 
bit. When bit 3 is a logic 1 and bit 4 is 
logic 0, and odd number of logic 1s is 
transmitted or checked in the data word 
bits and Parity bit. When bit 3 is logic 1 
and bit 4 is a logic 1, an even number of 
bits is transmitted or checked. 


Bit 5: This bit is the Stick Parity bit. 
When bit 3 is logic 1 and bit 5 is logic 1, 
the Parity bit is transmitted and then 
detected by the receiver in the opposite 
state indicated by bit 4. 


Bit 6: This bit is the Set Break Control 
bit. When bit 6 is a logic 1, the serial 
output (TXD) is forced to the Spacing 
state (logic 0) and remains there (until 
reset by a low-level bit 6) regardless of 
other transmitter activity. The feature 
enables the CPU to alert a terminal in a 
computer communications system. 


Bit 7: This bit is the Divisor Latch 
Access Bit (DLAB). It must be set high 
(logic 1) to access the Divisor Latches 
of the Baud Rate Generator during a 
Read or Write operation. It must be set 
low (logic 0) to access the Receiver 
Buffer, the Transmitter Holding Regis- 
ter, or the Interrupt Enable Register. 


Programmable Baud Rate Generator 
The VL7C413's Baud Rate Generator 
can be programmed for one of six baud 
rates. The desired speed is selected by 
writing into the Divisor Latch (DLM) . 
On reset, the rate will be 1200 baud. 


DLM (Hex Code) 
Baud Rate 
00 
1200 
01 
300 
O3 
150 
O4 
110 
06 
75 
09 
50 


Llne Status Reglster 
This 8-bit register provides status 
information to the CPU concerning the 
data transfer. The contents of the Line 
Status Register are indicated in Table 2 
and are described below: 


Bit 0: This bit is the receiver Data 
Ready (DR) indicator. Bit 0 is set to a 
logic 1 whenever a complete incoming 
character has been received and 
transferred into the Receiver Buffer 
Register. Bit 0 will reset to a logic 0 
either by the CPU reading the data in 
the Receiver Buffer Register or by 
writing a logic 0 into it from the CPU. 


Bit 1: This bit is the Overrun Error (OE) 
indicator. Bit 1 indicates that data in the 
Receiver Buffer Register was not read 
by the CPU before the next character 
was transferred into the Receiver Buffer 
Register, thereby destroying the 
previous character. The OE indicator is 
reset whenever the CPU reads the 
contents of the Line Status Register. 


Bit 2: This bit is the Parity Error (PE) 
indicator. Bit 2 indicates that the 
received data character does not have 
the correct even or odd parity, as 
selected by the even parity select bit. 
The PE bit is set to a logic 1 upon 
detection of parity error and is reset to a 
logic 0 whenever the CPU reads the 
contents of the Line Status Register. 


Bit 3: This bit is the Framing Error (FE) 
indicator. Bit 3 indicates that the 
received character did not have a valid 
Stop bit. Bit 3 is set to a logic 1 
whenever the Stop bit following the last 
data bit or parity bit is detected as a 
zero (Spacing level). 


Bit 4: This bit is the Break Interrupt (Bl) 
indicator. Bit 4 is set to a logic 1 
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whenever the received data input is 
held in the Spacing (Logic 0) state for 
longer than a full word transmission 
time - the total time of Start bit + data 
bits + Parity + Stop bits. 


Bit 5: This bit is the Transmitter Holding 
Register Empty (THRE) indicator. Bit 5 
indicates that the VL7C215 is ready to 
accept a new character for transmis- 
sion. In addition, this bit causes the 
VL7C215 to issue an interrupt to the 
CPU when the Transmit Holding 
Register Empty enable is set high. The 
THRE bit is set to a logic 0 concurrently 
with the loading of the Transmitter 
Holding Register by the CPU. 


Bit 6: This bit is the Transmitter Shift 
Register Empty (TSRE) indicator. Bit 6 
is set to a logic 1 whenever the Trans- 
mitter Shift Register is idle. It is reset to 
logic 0 upon a data transfer from the 
Transmitter Holding Register to the 
Transmitter Shift Register. 


Bit 7: This bit is permanently set to 
logic 0. 


Bits 1 through 4 are the error conditions 
that produce a Receiver Line Status 
interrupt whenever any ofthe corre- 
sponding conditions are detected. 


lnterruptldentlflcatlon Reglster 
The VL7C413 has an on-chip interrupt 
capability that allows for complete 
flexibility in interfacing to all popular 
microprocessors. To provide minimum 
software overhead during data charac- 
ter transfers, the VL7C413 prioritizes 
interrupts into four levels. The four 
levels of interrupt conditions are as 
follows: Receiver Line Status (priority 
1); Received Data Ready (priority 2); 
Transmitter Holding Register Empty 
(priority 3); and MODEM Status (priority 
4). 


Information indicating that a prioritized 
interrupt is pending the source of that 
interrupt are stored in the Interrupt 
Identification Register (refer to Table 7). 
The Interrupt Identification Register 
(IIR), when addressed during chip- 
select time, freezes the highest priority 
interrupt pending and no other inter- 
rupts are acknowledged until the 
particular interrupt is serviced by the 
CPU. The contents of the IIR are 
indicated in Table 2 and are described 
below. 
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Bit 0: This bit can be used in either a 
hardwired prioritized or polled environ- 
ment to indicate whether an interrupt is 
pending. When bit 0 is logic 0, an 
interrupt is pending and the IIR contents 
may be used as a pointer to the 
appropriate interrupt service routine. 
When bit 0 is a logic, no interrupt is 
pending. 


Bits 1 and 2: These two bits of the IIR 
are used to identify the highest priority 
interrupt pending as indicated in Table 
7. 


Bits 3 through 7: These five bits of the 
IIR are always logic 0. 


|nterruptEnabie Reglster 
This 8-bit register enables the four 
interrupt sources of the VL7C413 to 
separately activate the interrupt (INT) 
output signal. it is possible to totally 
disable the interrupt system by resetting 
bits 0 through 3 of the Interrupt Enable 
Register. Similarly, by setting the 
appropriate bits of this register and the 
active (high) INT output from the chip. 
All other system functions operate in 
their normal manner, including the 
setting of the Line Status and MODEM 
Status Register. The contents of the 
interrupt Enable Register are indicated 
in Table 2 and are described below. 


Bit 0: This bit enables the Received 
Data Available interrupt when set to 
logic 1. 


Bit 1: This bit enables the transmitter 
Holding Register Empty interrupt when 
set to a logic 1. 


Bit 2: This bit enables the Receiver 
Line Status Interrupt when set to logic 
1. 


Bit 3: This bit enables the MODEM 
Status Interrupt when set to logic 1. 


Bit 4 through 7: These four bits are 
always logic 0. 


MODEM Control Reglster 
This 8-bit register controls the interface 
with the MODEM. The contents of the 
MODEM Control Register are indicated 
in Table 2 and are described below. 


Bit 0: This bit controls Data Terminal 
Ready (DTR) signal. If the external 
switch on the -RD pin is set to VCC 
through an 18 kQ resistor, setting the 
DTR low will force the VL7C413 into the 
command state and if on line, it will 
hang up. 


Bit 1: This bit controls the Request to 
Send (RTS) signal. This signal is not 
used by the VL7C413. 


Bit 2: This bit controls the Output 1 
(OUT1) signal. This signal is not used 
by the VL7C413. 


Bit 3: This bit controls the Output 2 
(OUT2) signal. When OUT2 is a O, the 
interrupt output is in high impedence 
state. 


Bit 4: Not used. 


Bits 5 through 7: These bits are 
permanently set to logic 0. 


MODEM Status Register 
This 8-bit register provides the current 
state of the control lines from the 
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MODEM (or peripheral device) to the 
CPU. In addition to this current-state 
information, two bits of the MODEM 
Status Register provide change 
information. These bits are set to a 
logic 1 whenever a control input from 
the MODEM changes state. They are 
reset to logic O whenever the CPU 
reads the MODEM Status Register. 


The contents of the MODEM Status 
Register are indicated in Table 2 and 
are described below. 


Bits 0 and 1: 
- These bits are always 0. 


Bit 2: This bit is the Trailing Edge of 
Ring Indicator (TERI) detector. Bit 2 
indicates that the -RI input to the chip 
has changed from On (logic 1) to an Off 
(logic O) condition. 


Bit 3: This bit is the Delta Received 
Line Signal Detector (DRLSD) indicator. 
Bit 3 indicates that the carrier detector 
has changed state. 


Bit 4: Thisbit is always 1. 


Bit 5: This bit is always 1. 


Bit 6: This bit is the complement of the 
Ring Indicator (-RI) input. 


Bit 7: This bit is the Received Line 
Signal Detect (RLSD) signal. 


Whenever bit 2 is set to logic 1, or bit 3 
changes state, a MODEM Status 
Interrupt is generated if enabled. 
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TABLE 7. INTERRUPT CONTROL FUNCTIONS 


Interrupt 
Id9"i|lI¢8l|°I1 
Interrupt Set and Reset Functions 
Reglster 


Bit 2 
pomy 
interrupt Flag 
Interrupt Source 
Interrupt 


O 


I 


Level 
Reset Control 


Receiver 
Overrun Error or 
Reading the Line 
Line Status 
Parity Error or 
Status Register 
Framing Error or 
Break Interrupt 


1 
Second 
Received Data 
Received Data 
Reading the Receiver 
Available 
Available 
Buffer Register 


O 


0 


Third 


Fourth 


Transmitter Holding 
Transmitter Holding 
Reading the IIR (if source of 
Register Empty 
Register Empty 
interrupt) or Writing into the 
Transmitter Holding Register 


MODEM Status 
Ring indicator or 
Reading the MODEM 
Received Line 
Status Register 
Signal Detect 
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FIGURE 2. ADDRESS DECODER CIRCUIT 
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AC CHARACTERISTICS: TA = o TO 1o~c, vcc = s v 110% 


Symbol 
Parameter 
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Condltlons 
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FIGURE 3. READ CYCLE TIMING 
4 
tACR 
-CS 
V 
A0, A1, A2 
VALID 
I 
A 


® VLSI TECHNOLOGY, INC. 


I<i- tDiC 


tDIW 


VL7C413 


tRC 


-DIST 
ACTIVE 
ACTIVE 
Z 


OR 
T 
-DOST 
I 
ACTIVE 
no 


tDDD 
I4 tHZ 


DATA 
VALID 
D0-D7 
DATA 


IORDY 


FIGURE 4. WRITE CYCLE TIMING 
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FIGURE 5. RECEIVER TIMING 
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FIGURE e. TRANSMITTER TIMING 
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ABSOLUTE 
MAXIMUM 
RATINGS 


Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. Expo- 
Temperature 
0°C to +70°C 
permanent damage to the device. 
sure to absolute maximum rating 
storage Temperature 
_650C to H5000 
These are stress ratings only, functional 
conditions‘ for extended periods may 
operation of this device at these or any 
affect device reliability. 
Suppw V°IIa9e_ Io 
other conditions above those indicated 
Ground Potential 
+6 V 


Applied Input 
Voltage 
-0.6 V to VCC +0.6 V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = 0 to +70 °c, vcc = 5 v -110% 


Symbol 
Parameter 


VCC 


ICC 


VIH 


VIL 


VT+ 


VT- 


VOH 


VOL 


IL 


FCLK 


Note : 



Conditions 


I“Potn 


ix:-I 


<<< 


Positive Supply Voltage 


perating Current 
A 
@ VCC = 5 V 


All pins except -RI 


All pins except -RI 


-RI pin 


High Level Input Voltage 


.°.0 
:>A 


T: 


Low Level Input Voltage 


Positive Hysterisis Threshold 


Negative Hysterisis Threshold 
—Rl pin 


Digital signal pins D0 to D7 
and INT @ IOH = -6 mA 


All other output or I/O pins 
@ IOH = -2 mA 


Digital signal pins D0 to D7 
and INT @ IOL = 6 mA 


All other output or I/O pins 
@ IOL = 2 mA 


VC -10 
High Level Output Voltage 


VC 
-10 


Low Level Output Voltage 


Leakage Current (Note) 
i 
0 


Clock Frequency 
7.3721 
7.3728 
7.3735 
MHz 


This applies to all pins except TEST, which has an internal pull-down -WR, -RD, SCK, DI/O and switch input pins 
which have internal pull-ups. 


478 


8 VLSI TECHNOLOGY, INC. 


r 
VL7C413 


FIGURE 7. INTEGRAL SMART MODEM CONFIGURATION FOR PC BUS APPLICATIONS 
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STAND-ALONE MODEM INTERFACE CONTROLLER 
WITH AUTOMATIC MODEM POWER DOWN CONTROL 


FEATURES 


- Direct interface to VL7C412A single 
chip single-supply modems 


- Complete Hayes AT command set in 
firmware 


- Built-in UART for RS232C interface 


- Two-micron CMOS process 


- 28-pin DIP or PLCC package 


- Complete intelligent modem in two ICs 


- Compatible with industry-standard 
software 


- Reduces board space and component 
count requirements 


- Low power consumption 


- Replacement for Sierra SC11028 


PIN DIAGRAMS 


N.C. 
N.C. 
TEST 
KDV/-KDV 
-RI 
ow-on 
CLK 
-we 
-RD 
SCK 
DI/O 
TXD 
axe 
one 


VL7C414 
12a45e7e91o 
11 
12 
1:1 
14 


28 
27 
26 
25 
24 
23 
Z 
21 
20 
19 
18 
17 
16 
15 


vcc 
-DTR 
-co 
-AA 
-HS 
N.C. 
MS SEL 
212A/-v.22 
-CMD EN 
-AA DIS 
ECHO EN 
-RES EN 
WORD 
-PS 


TEST 
N.C. 
-DTR 
KDV! 
—KDVI 
4 
-RI I 
5 


OH/—OH I 
e 


CLK I 
7 
-we I 
e 


-RD I 
9 


SCK I 1o 


“I 
0-I 
8-§SI 8-33 


TOP VIEW 


DI/O .1112 
I 


25 I -AA 


24 I -HS 


23 I 


22 I 


21 I 


19 I -AA DIS 


DESCRIPTION 
The VL7C414 Stand-Alone Modem 
Interface Controller is specifically 
designed to control the VL7C412A 
single-chip, 300/1200 bit-per-second 
modem. Built with an advanced two- 
micron CMOS process, the VL7C414 
provides a highly cost effective 
solution for interfacing a modem IC to 
a computer's RS232C port. When 
connected to the VL7C412A, with the 
addition of a data access arrangement 
(DAA), the VL7C414 implements a 
Hayes-type smart modem for stand- 
alone modem applications. All of the 
popular communications software 
written for the IBM PC will work with 
the VL7C414/VL7C412A chip set. The 


BLOCK DIAGRAM 


VL7C414 contains an 8-bit microproces- 
sor, 8K by 8 bits of ROM and 128 by 8 
bits of RAM. In order to support the 
stand-alone functionality of the device, 
an 8-bit switch input port allows immedi- 
ate user access and manual control of 
the system. Either Bell 103 or CCITT 
V.22 may be selected in this manner. 


The VL7C414 automatically controls the 
power up/down feature of the VL7C412 
to maintain lowest possible system 
power consumption. 


For specific high volume applications, 
the control program can be modified by 
VLSI Technology, Inc. to include 
additional commands and functions. 


UART 


UAQT 
BAUD RATE 
TRANS 
TXD 
INTERFACE 
REGISTERS 
TROL 
RCVR 
RXD 


UART MONITOR 
UART CONTROL 
REGISTER 
REGISTER 


ROM BLOCK 
PC/SUBROUTINE 
REGISTER 
STACK 


Q 
l 
- 


(J 


N.C. 


ROM 
8K X 8 


INSTRUCTION 
REGISTER 


8 
I 
: 
TIMER 
CONTROL --.1 


212A/-V.22 


20 . _(;M[)EN 
ACCUMULATOR 


3 
14 
15 
1s 11 
1a 
I I I I I I I 
M 
TXD 
GND 
wono 
ECHO EN 
RA 
12a x e 
a 
“ 
RXD 
-PS 
-RES EN 
PQRT 1 


ORDER INFORMATION 
W553 
DIIS 
-RES EN 
Part 
-AA DIS 
'iL“3I§ 
Number 
Package 
21*‘,§3A'>’i_l?/E; 
VL7C414-PC 
Plastic DIP 
MS SEL 
VL7C414-QC 
Plastic Leaded Chip Carrier (PLCC) 
-HS -AA CD -DTR 
KDV -on -RI 


Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL 
DESCRIPTIONS 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


N.C. 
1 
No connection 


N.C. 
2 
No connection 


TEST 
3 
When the test input is high, the VL7C414 enters a test mode (used for factory testing 
only). For normal operation, this pin can be left open or connected to ground. 


KDV/-KDV 
4 
This output controls the operation of the data/voice relay. The polarity of this output is 
selected by —PS pin. If —PS is connected to ground, this output is active high, i.e., it is 
low when modem is on hook, causing the data/voice relay to be off and the phone line is 
connected to the phone set. 
During a data call, this output goes high to operate the 
data/voice relay, disconnecting the phone set from the phone line. It may also be used 
to drive a relay for multi-line phone applications to close the A and A1 leads. If -PS pin 
is left open or connected to VCC, this output is active low, i.e., it is high when the modem 
is on hook and low when modem makes a data call. 


—-Fll 
5 
The output of the ring detector in the DAA is connected to this input. A low level on this 
input indicates the "On" duration of the ring cycle. This is a Schmitt-trigger input, 
allowing for slow rising and falling signals on this pin. 
OH/-OH 
6 
This output controls the operation of the hookswitch relay in the DAA. The polarity of this 
output is selected by -PS pin. lf -PS pin is connected to ground, this output is active 
high, i.e., it is low when the modem is on hock. During a data call, it goes high to 
operate the hookswitch relay and seize the phone line. During rotary dialing, the 
VL7C414 pulses this output at a rate of 10 pulses per second with appropriate Mark! 
Space ratio depending on 212A or V.22 mode. If -PS pin is left open or connected to 
VCC, this output is active low, i.e., it is high when the modem is on hook and low during 
data call. 


CLK 
7 
A 7.3728 MHz clock signal must be connected to this input. Normally, the CKOUT pin of 
the VL7C412A modem is connected to this pin. All internal timing is derived from this 
clock. 


--WR 
8 
This pin is used to initiate writing of data to the VL7C412A modem. 


-RD 
9 
This pin is used to initiate reading of data from the VL7C412A modem. 


SCK 
10 
The VL7C414 supplies a shift clock on this pin to the VL7C412A modem for reading or 
writing data. 


DI/0 
11 
The VL7C414 shifts data serially out of this pin to VL7C412A during a write operation 
and shifts data serially into this pin during a read operation from the VL7C412A. 


TXD 
12 
The VL7C414 outputs serial data in asynchronous start/stop format at the data rate 
selected by the terminal. This data is either echo of commands received from the 
terminal or result wdes generated by the controller during processing of the commands. 
This output is normally high and should be "AND"ed with the RXD output of the 
VL7C412A to form RXD data to the terminal. 


RXD 
13 
The VL7C414 receives command data from the terminal on this pin. The UART in the 
controller connects the serial asynchronous start/stop data into a parallel byte for 
processing by the controller. 


GND 
14 
Ground reference (0 V). 


—PS 
15 
This input controls the polarity of KDV and OH outputs. When left open or connected to 
VCC, it forces the KDV and OH outputs to be active low. If this input is connected to 
ground, KDV and OH outputs are active high. 


WORD 
16 
When the input is open or wnnected to VCC, the VL7C414 sends result codes as words. 
When this input is low, result wdes are sent as digits. This setting can also be changed 
by entering the V command. 
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SIGNAL 
DESCRIPTIONS 


Slgnal 
Name 


-RES EN 


ECHO EN 


-AA DIS 


-CMD EN 


212A/—V.22 


MS SEL 


N.C. 
-HS 


—AA 


-CD 


-DTR 


VCC 


Pln 
Number 


17 


18 


19 


20 


21 


22 


23 


24 


25 


26 


27 


28 


(Conn) 


Slgnal 
Descrlptlon 


When this input is low, the VL7C414 sends result codes. When this input is high or left 
open, commands received from the terminal are performed but result codes are not sent. 
This setting can also be changed by entering the Q command. 


When this input is high or left open, the VL7C414 echoes characters received from the 
terminal in the command state. When this input is low, the VL7C414 will not echo char- 
acters unless it is set for half duplex and it is on line. This setting can also be changed 
by entering the E command. 


When this input is low, the VL7C414 will not answer incoming calls. When this input is 
high or left open, the VL7C414 automatically answers incoming calls on the first ring. 
This function can also be enabled/disabled by writing to the SO register. 


When this input is low, the VL7C414 recognizes command sent to it. For some applica- 
tions such as unattended answering operation it is better to disable this function by 
leaving this input open or connecting it to VCC. 


When this input is open or connected to VCC, the VL7C414 supports Bell 103 and 212A 
modes. When this input is low, the VL7C414 supports the CCITT V.22 and V.21 modes. 
This setting can also be changed by entering the B command. 


When this input is open or connected to VCC, the Mark/Space ratio is U.S. standard, 40/ 
60 Make/Break. When it is low, the Mark/Space ratio is European standard, 33/67 Make! 
Break. 


No connection 


This output, when low, indicates that the modem is in the high speed (1200 bps) mode. 
When high, it indicates that it is in the low speed (300 bps) mode. This output can be 
directly connected to a light emitting diode through a 330 Q resistor. 


This output is low when the VL7C414 is set for auto-answer mode, either by switch input 
-AA DIS (pin 19) or register SO. The output goes high during each ring. If the device is 
not set to answer the phone (pin 19 is low or S0 = 0), this output goes low each time the 
phone rings. A light emitting diode through a 330 Q resistor can be directly connected to 
this output. 


This output goes low when the VL7C414 detects a carrier signal from the remote 
modem. lf the connection is broken or never established, it remains high. A light 
emitting diode can be directly connected to this output through a 330 Q resistor. 


When this input is low, the VL7C414 executes data call commands. If during a data call, 
this input goes high, the VL7C414 terminates the data call, hangs up the phone line and 
returns to command state. 


Positive supply (+5 V). 
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N 


Reglster 


SO 


S1 


S2 


S3 


S4 


S5 


S6 


S7 


S8 


S9 


S10 


S11 


S12 


S13 


S14 


S15 


S16 


TABLE 1. VL7C414 SOFTWARE REGISTERS 


Ring to answer telephone 


VLSI TECHNOLOGY, INC. 


Range/Units 
Descrlptlon 


on 


Number of rings 


0 127 ASCII 
Escape code character 


0 127 ASCII 
Character recognized as carriage return 


0-127 ASCII 
Character recognized as line feedback 


0 32 127 ASCII 
Character recognized as back space 


Wait time for dial tone 


Wait time for carrier 


Pause time (caused by comma) 


1 255 1/10 sec 
Carrier detect response time 


1 255 1/10 sec 
Delay between loss of carrier and hang up 


50 255 millisec 
Duration and spacing of Touch Tones 


20 255 1/50 sec 
Escape code guard time 


bit mapped 
UART status register 


bit mapped 
Option register 


bit mapped 
Flag register 


Test modes 
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Default 


0 


0 


43 (+) 


13 (CR) 


10 (LF) 


8 (BS) 


2 


30 


2 


6 


7 


70 


50 
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TABLE 2. COMMAND SUMMARY 
PREFIX, REPEAT AND ESCAPE COMMANDS 


Command 
Descrlptlon (Notes 1 & 2) 


AT 


A/ 


+++ 


Attention prefix: precedes all command lines except + + + (escape) and A/(repeat) commands 


Repeat last command line (Al is not followed by carriage return) 


Escape code: go from on-line state to command state (one second pause before and after escape 
code en1FY; ; + + + is not followed by carriage return) 


DIALING COMMANDS 


Command 
Descrlptlon (Notes 1 & 2) 


D 


P 


T 


Descrlptlon (Notes1 & 2) 


Waitfor1/8 second 


Wait for silence 


Touch Tone 
Wait for second dial tone 


Pause 


Flash 


Return to command state after dialing 


Reverse mode (to call originate-only modem) 


OTHER COMMANDS 


Commands 


A 


B/B0 


B1 


C/C0 


C1 


E/E0 


E1 


F/F0 


F1 


H/H0 


H1 


H2 


I/I0 


I1 


I2 


L/L1 


L2 


L3 


M/M0 


Notes: 
1 
2. 
3. 


Descrlptlon (Notes 1 & 2) 
Commands 
Descrlptlon (Notes 1 & 2) 


(D 


0 


Answer call without waiting for ring 


CCITT V 22 mode (Note 3) 


Bell 103 and 212A mode 


Speaker on until carrier detected‘ 


Speaker always on 


Go to on-line state 


Transmit carrier off 
Remote digital loopback off‘ 


Carrier on 
Remote digital loopback request 


Characters not echoed 
O/Q0 
Result codes displayed‘ 


Characters echoed 
Result codes not displayed 


Half du lex 
r 
Requests current value of register r 
D 


Full duplex 
Sr = n 


VNO 


Sets register rto value of n 


On hook (hang up) 
Digit result codes 


Off hook, line and auxiliary relay 
Word result codes‘ 


Off hook, line relay only 
X/X 
Compatible with Hayes-type 300 modems‘ 


Request product ID code (130) 
Result code CONNECT 1200 enabled 


Firmware revision number 
Enables dial tone detection 


Test internal memory 
Enables busy signal detection 


Low speaker volume 
Enables dial tone and busy signal detection 


Medium speaker volume 
Y/Y0 
Long space disconnect disabled‘ 


High speaker volume 
Long space disconnect enabled 


Speaker always off 
Software reset: restores all default settings 


Default modes are indicated by ". 
Commands entered with null parameters assume 0 - X is the same as X0. 
When the ATB command is used in the answer mode, the VL7C412A is placed in either the V.21 or the V.22 mode, 
depending on the response from the remote modem. In the originate mode, the VL7C414 will sense if the baud rate is 
set at 300 or 1200 bits per second and will adjust the VL7C412A accordingly. 
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TABLE 3. RESULT CODES 


Digit Code 
Word Code 
Descrlptlon 


I 
I 


0 
Command executed 


Connected at 300 or 1200 bps 
I 
Connected at 300 bps, if result of X1, X2, X3, or X4 command 


2 
Ringing signal detected (Note) 
. 


3 
No Carrier 
Carrier signal not detected or lost 


1 


illegal command 
4 
Error in command line 
Command line exceeds buffer (40 characters, including punctuation) 
Invalid character format at 1200 bps 


5 
Connect 1200 
Connected at 1200 bps. Results from X1, X2, X3, or X4 commands only 


Dialtone not detected and subsequent commands not processed 
Results from X2 or X4 commands only 


Busy signal detected and subsequent commands not processed 
' 
Results from X3 or X4 commands only 


6 
No Dialtone 


7 
Busy 


Silence not detected and subsequent commands not processed 
Results from @ command only 


Note : When the VL7C414 detects a ringing on the telephone line, it sends a RING result code. However, the VL7C414 
will answer the call only if it is in auto-answer mode or is given an A command. 


8 
No Answer 
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ABSOLUTE 
MAXIMUM 
RATINGS 
Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. Expo- 
Temperature 
0°C to +70°C 
permanent damage to the device. 
sure to absolute maximum rating 
Storage Temperature 
_65.,C to +1 50°C 
These_are stress ratings only, functional 
conditions. for extended periods may 
operation of this device at these or any 
affect device reliability. 
SUPPIY V°"a9°_ t° 
other conditions above those indicated 
Ground Potential 
+6 V 


Applied Input 
Voltage 
-—O.6 V to VCC + 6 V 


Power Dissipation 
500 mW 


DC CHARACTERISTICS: TA = o to +70 <>c, vcc = 5 v ¢1o% 


Symbol 
Parameter 
T 
Condltlons 


VCC 
Positive Supply Voltage 
. 


ICC 
Operating Current 
A 
@ VCC = 5 V, outputs unloaded 


VIH 
High Level Input Voltage 
All pins except --Rl 


VIL 
Low Level Input Voltage 
All pins except —RI 


VT+ 
Positive Hysterisis Threshold 
—RI pin 


VT— 
Negative Hysterisis Threshold 
—Rl pin 


VOH 
High Level Output Voltage 
VC 
— 1 0 
@ IOH = -2 mA 


VOL 
Low Level Output Voltage 
@ IOL = 2 mA 


IL 
Leakage Current (Note) 
:t 
0 


FCLK 
Clock Frequency 
7.3721 
7.3728 
7.3735 
MHz 


Note : 
This applies to all pins except TEST, which has an internal pull-down -WR, -RD, SCK, Dl/O, and switch input pins 
15 thru 21 which have internal pull-ups. 


OA 


on 


r‘ 
~< 


9A 
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FIGURE 1 . 212AN.22 STAND-ALONE INTELUGENT MODEM USING THE VL7C412A MODEM IC 
AND THE VL7C414 
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Note: Schematics are for illustration purposes only. Operational systems may require modifications. 
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FIGURE 1. 212A/V.22 STAND-ALONE INTELLIGENT MODEM USING THE VL7C412A MODEM IC 
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N VLSI TECHNOLOGY, INC. 
VL80C75 


FEATURES 
DESCRIPTION 


- Supports T1, T1 C, and CEPT data 
The VL80C75 is a general purpose PCM 
rates 


- AMI, B8ZS, HDB3 format 


- Meets AT&T Technical Advisory #34 
for DSX1 and DSX1 C interface 
standards, publication 43802 
standard for jitter tolerance, and jitter 
standard for digital channel bank 


- Meets CCITT recommendation G.703 
for 1.544M bps and 2.048M bps 


- Input frequency memory 


- Jittersmoothing FIFO 


- Loopback and data path configurable 


- Bipolar violation detection & flagging 


Line Interface circuit. It is designed to 
provide a bipolar interface according to 
T1 (1.544M bps), T1C (3.152M bps), or 
CEPT (2.048M bps) specifications. It is 
capable of sending (encoding) and 
receiving (decoding) AMI, B8ZS or HDB3 
data formats. 


The incorporation of on-chip voltage 
comparators and adaptive reference 
levels allows direct interface to the 
analog line signal. Sensitivity is opti- 
mized by monitoring the incoming bipolar 
signal. 


An injection locking divider permits clock 
recovery from the incoming serial data 
stream. A 32-bit long FIFO (elastic 
- AIS, LOS, Overrun/Underrun detection 
buffer) may be used in either the 
and flagging 


- Microprocessor compatible interface 


- Low power CMOS technology 


PIN DIAGRAM 


VL80C75 


BDI I 
1 
24 I 
AGCN I 2 
23 I 
(;|_K| 
AGCP I 3 
22 I 
[)1 
NC I 4 
21 I 
CLKO 
RCLK I 5 
2Q I 
DO 


VDD 


decoder or the encoder path to smooth 
clock jitter. A DC output signal is pro- 
vided to facilitate the control of an 
external VCO. 


BLOCK DIAGRAM 


DI 


CLKI 


DECODE 


AGCP 


T1 INTERFACE 


The VL80C75 will indicate the presence 
of bipolar violation in the input data as 
well as a FIFO underflow/overflow. 


Interfacing to the external bipolar line 
driver is facilitated by the provision of 
50% duty cycle drive pulses. 


The system interface is microprocessor 
compatible. The internal control and 
status registers may be accessed by a 
parallel interface. 


System test is assisted by the provision 
of a loopback feature which operates in 
both directions. 


The VL80C75 is fabricated in a double 
' 
metal, n-well, two micron silicon gate 
CMOS process and is housed in a 24- 
pin 300 mil DIP or ceramic package. 


DATA 
CROSS I 
POINT 
ENCODER 


SW 
DO 
CLKO 


OMARKP 


OMARKi\ 


OMARKP I 6 
19 
OMARKN I 7 
18 
D0 
8 
17 
D19 
16 


D2 I 10 
15 
D3 I 
11 
14 
VSS 
I 
12 
13 
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LC 
RST 
RS 
-cs 
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-RE 
04 


BDI 


AGCN 


RCLK 
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+ 
DA A 
ICLK 
DATA 
BIAS 
sgp 
CLOCK 
+ 
A0 DATA 
2X32'B'T 


REG 
CODE 
R CLK 
I 
‘J’I 


|MARKIII 
"INJ 
D4 


DIV 
D2 
_ 
D1 
B'A3 
DIVIDE 
DIVIDE 
CONT 


ORDER INFORMATION 
Part 
Number 
Package 


VL80C75-PC 
Plastic DIP 
VL80C75-CC 
Ceramic DIP 
Note: Operating temperature range is 0 C to +70 C. 


00 
-RE 


—CS 
RS 
RST 
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_ 
VL80C75 
Signal Descriptions 


Slgnal 
Pln 
Slgnal 
Name 


BDI 


AGCN 


AGCP 


RCLK 


OMARKP 


OMARKN 


D0 - D4 


VSS 


-RE 


—-WE 


—CS 


RS 


RST 


LC 


DO 


CLKO 


DI 


CLKI 


VDD 


Number 


1 


2 


3 


5 


6 


7 


8-11,13 


12 


14 


15 


16 


17 


18 


19 


20 


21 


22 


23 


24 


Name 


Bipolar Data Input - The received analog line signal is capacitively wupled to this high imped- 
anceinput 


Automatic Gain Control Output (Negative) - This output is used to provide an automatically 
adjusted threshold voltage to the analog input comparators. A 0.1 i1F capacitor to VSS, a 


1 MQ resistor to pin 3, and a 4.7 MQ resistor to VDD should be attached to this pin. 


Automatic Gain Control Output (Positive )- See AGCN. A 4.7 MQ resistor to VSS instead of 
VDD should be used, however. 


Reference Clock - This TTL input should have a clock which is 8 times the line frequency 
(T1: 12.352 MHz, T1C: 25.216 MHz, CEPT: 16.284 MHz). This clock is used internally to 
recover the clock from the incoming received analog signal and is used to clock data out of 
the jitter smoothing FIFO. 


Output Mark (Positive) - Encoded data for driving positive line pulses appear at this output. 


Output Mark (Negative) - Encoded data for driving negative line pulses appear at this output. 


Data I/O - Configuration and status data is input or output on these bidirectional pins. 


Negative Power Supply - Normally ground. 


Read Enable - A low on this input enables the IC to output either the present configuration 
control data or the alarm status data on the D0-D4 data pins depending on the state of RS. 


Write Enable - A low on this input enables the writing of configuration data on the DO-D4 
data pins. This pin must not be low at the same time as the -RE pin. 


Chip Select - A low on this pin enables the reading or writing of data into the IC. 


Read Select - A high on this input selects the configuration data to output during a read while 
a low selects the alarm status data to be output. 


Reset - A logic high on this input initializes the internal configuration registers, resets the 
alarm status bits, and initializes the jitter filter. 


Loop Control - This output is used to control an external VCO or VXO to provide a stable 
RCLK signal. The duty cycle will be 50% if the write clock to the jitter smoothing FIFO is 
centered. The duty cycle will shorten or increase in proportion to the FIFO fill status. 


Data Output - Decoded and received data is normally output on this pin. 


Clock Out - Data on the DO pin is output on the rising edges of this clock signal. 


Data In - NRZ Data on this input is normally encoded and output at the OMARKP and 
OMARKN pins. 


Clock In - This input is used to clock the data on the DI pin into the IC on rising edges of this 
signal. Nominally a 50% duty cycle signal. 


Positive Power Supply - Normally, +5 V. 
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FUNCTIONAL DESCRIPTION 
The VL80C75 consists of two separate 
sections, the line receiver and the 
the line transmitter. 


The receiver accepts a bipolar (ternary) 
input signal and converts it into a 
decoded data stream. A clock signal is 
extracted from the incoming data 
stream. 


The transmitter converts a digital input 
data stream into two output drive pulses; 
these pulses drive external transistors 
which, in turn, drive the transmission 
lines through line build out circuits, or 
directly via a transformer. Data zeros 
are represented by the absence of a 
pulse in the output and ones are repre- 
sented by a pulse from one or the other 
transistor. The polarity of these pulses 
typically alternate so that the DC content 
of the signal equals zero. 
Voltage Comparators 
The function of these comparators is to 
convert the incoming bipolar data stream 
into two logic signals which correspond to 
a positive or negative pulse on the input 
line. 


Mark Registers and Blas Drlvers 
The VL80C75 samples the comparator 
outputs, and stores the pulses in the mark 
registers. Should the input data pulse 
width deviate from 50%, the AGC signals 
(AGCP and AGCN) will alter the refer- 
ence voltage of the comparators in such a 
way that the output pulse width from the 
comparators will drive the recovered 
pulses‘ duty cycle towards 50%. 


Data and Clock Recovery 
This circuit extracts the clock from the 
input stream by means of an injection 
lock divider. The divider responds to the 
leading edge of the recovered pulses by 
resetting an internal divider to zero. If 
there is no"mark" on the input then the 
divider will operate in its free running 
mode and generate a square wave clock. 
If a pulse is detected, the leading edge of 
the recovered clock is reset. 


Data Decoder 
The decoder converts input data format of 
either AMI, B828 or HDB3 code into NRZ 
data. This circuit also detects bipolar 
format violations on the input data. The 
VL80C75 operates using either AMI, 
B828, or HDB3 coding formats. 
AMI (Alternate Mark lnversion)- In this 
mode a positive "mark" is always 


followed by a negative "mark" and vice- 
versa. This process ensures that no DC 
component exists in the signals. Zeros 
are represented by the absence of 
pulses. Consecutive zeros exceeding 15 
bits are usually not allowed since clock 
information is not present in this condi- 
tion. However, the 80C75 will always 
maintain a recovered clock based on the 
last received mark position. 


B828 (Bipolar 8 Zeros Suppression) 
In this coding format, the input data 
pattern follows the AMI code except that 
a B828 code is substituted for each 
block of eight consecutive zeros. This 
assures steady clock updates regardless 
of the data pattern. The B828 format is 
OOOVBOVB, where B stands for an AMI 
pulse and V is a pulse which violates that 
rule. 


HDB3 (High Density Bipolar 3 code) 
This format obeys the AMI rule except 
that a HDB3 filling sequence is inserted 
for each block of four consecutive zeros. 
The filling sequences are shown below. 


Prevlous 
Previous 
Fllllng 
Mark (B, V) 
Vlolatlon (V) 
Sec. 


+ 
+ 
- 0 0 - 


+ 


+ 
000- 
000+ 
+00+ 


Data Encoder 
The encoder transforms the NRZ input 
data into coded bit pattern of 
either AMI, B828 or HDB3 format 
depending on the bit code C0 and C1. 
The output signals (OMARKP, 
OMARKN) are used to drive the trans- 
mission lines via external transistors. 


FIFO (Flrst-In Flrst-Out Reglster) 
This circuit has 32 stages and is 2 bits 
wide and is used to eliminate jitter. 
5 bit access counters in the FIFO 
provide the data read and write ad- 
dresses. The read count is offset by 16 
bits with respect to the write count when 
initialized. 


The write clock (normally the recovered 
data clock) transfers data into the FIFO. 
The read clock (normally RCLK + 8 
which comes from an external VCO and 
does not contain jitter) transfers data out 
the FIFO, normally 16 bits of delay later. 
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The frequency of the external VCO is 
controlled by signal Loop Control, LC, of 
the FIFO. If the write clock runs faster 
or slower than the read clock, the 
resultant DC voltage of LC will cause 
the VCO to raise or lower its frequency 
and thereby correspondingly changing 
the read frequency. 


The range in which the read clock can 
track the write clock is dependent on the 
loop gain and the external crystal 
oscillator. 


Overflow or underflow occurs when the 
read and write counts are equal. When 
this condition is detected it is flagged 
and the FIFO is reinitialized. 


Cross Polnt Swltch 
This switch enables the internal signals 
of theVL80C75 to be routed to allow 
various configurations of the jitter filter 
and data paths. 


Dlvlde by 8 Counter 
This is a 3-bit binary up counter. The 
counter divides the incoming 
reference clock, RCLK, by a factor of 
eight. The RCLK frequency is of either 
8 x T1 rate (12.352 MHz), 8 x T1C rate 
(25.216 MHz) or 8 x CEPT rate (16.384 
MHz). The MSB output of this counter 
serves as the read clock for the FIFO. 


Zeros and Ones Detect 
This circuit detects the receipt of a 
string of 63 consecutive zeros (implying 
the line is disconnected) or 1023 con- 
secutive ones ("Blue Alarm“ or AIS) on 
the input ternary data stream and flags 
these conditions in a status register. 


PROGRAMMING 
The VL80C75 may be configured for 
several modes of operation. Control 
data is written into the VL80C75 via the 
D0-D4 pins when —CS and -WE pins 
transition from low to high, while the 
alarm status or present control data may 
be read out on these pins when -CS 
and -RE are low. The encode/decode 
mode and the internal configuration of 
the 80C75 are controlled by the data 
written on the D0-D4 pins according to 
Table 1. 
The control data or alarm status is 
output on the D0-D4 pins when -CS and 
-RE are low according to Table 2. 


Rs in ohms, Cs in 
microiarads 
Unless otherwise 


§.LQ§.EDLQEEN. 


S1 READ/WRITE 
S2 ALARM/CONFIGURATION 
S3 LB2 = 0/1 
S4 LB1 = 0/1 
S5 LBO = 0/1 
S6 M1 = 0/1 
S7 M0 = 0/1 


S1 


S2 


S3 


S4 


S5 


S6 


7X1K 
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FIGURE 1 
VL80C75 EVALUATION CIRCUIT 
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FIGURE1 . VL80C75 EVALUATION CIRCUIT (Cont.) 
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TABLE 1. WRITE DATA 


Control Blt Name I Data Llne 


LB2 /D0 
LB1 /D1 
LBO /D2 


X 


X 


X 


0 


0 


0 


0 


1 


1 


C1 /D3 
C0 /D4 


TABLE 2. READ DATA 


Blt 


D0 


D1 


D2 


D3 


D4 


FIFO Overflow 


FIFO Underilow 


AIS, > 1023 Consecutive Ones 


LOS, > 63 Consecutive Zeros 


Bipolar Violation 


Note: Alarm bits reset after read. 


EVALUATION CIRCUIT 
A typical evaluation circuit is shown in 
Figure 1. This circuit provides the 
ability to read and write data into the 
VL80C75 and provides a simple 
interface to the twisted pair. Line build 
out circuitry is not included in this 
schematic but can be easily added for a 
given application. Atypical T1 Multi- 
plexer applications is shown in Figure 2. 


VL80C75 


Operating Mode 


AMI Coding 


B828 Coding 


HDB3 Coding 
I 


Jitter Filter in Transmit Path: DI to Jitter to OMARKN/P; BPI to DO 


Jitter Filter in Receive Path: DI to OMARKN/P; BPI to Jitter to DO 


Loopback, Jitter Filter in TX: DI to Jitter to DO; BPI to OMARKN/P 


Loopback, Jitter Filter in RX: DI to DO; BPI to Jitter to OMARKN/P 


Loopback: DI to DO; BPI to OMARKN/P 


No Jitter Filter: DI to OMARKN/P; BPI to DO 


HS = 0 


LB2 


LB1 


LBO 


C1 
T’ 


C0 
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FIGURE 2. TYPICAL APPLICATION 
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T1 SPAN 


2 TWISTED PAIRS, 
1.544 MHZ AMI 
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AC TEST CONDITIONS 


Input Pulse Levels 
GND to 3.0 V 
Input Rise and Fall Times 
10 ns 
Input Timing Levels 
1.5 V 
Output Reference Levels 
1.5 V 


AC CHARACTERISTICS: TA=0to 70 C,VDD=5 V 10%, unless otherwise noted. 


WW 
II- 
— 


U1 


25 216 
MHZ 


-CS,-RE 


Condltlon 


RS 
‘ 
. 


D0 ' D4 
DATA VALID 


tACC 
"‘ 


-CS,-WE 


D0 - D4 


VALID DATA 


L 
tsui> 
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ABSOLUTE 
MAXIMUM 
RATINGS 
Ambient Qperating 
Stresses above those listed under 
the operational sections of this specifi- 
Temperature 
-1010 +30°c 
"Absolute Maximum Ratings” may cause 
cation is not implied. Exposure to 
Storage Temperature 
__65 to +1 50°C 
permanent damage to the device. These 
absolute maximum rating conditions 
are stress ratings only. Functional 
for extended periods may affect device 
Supply Voltage to 
operation of this device at these or any 
reliability. 
Ground Potential 
-0.510 +7.0 V 
other conditions above those indicated in 


Applied Output 
Voltage 
-0.5 to +7.0 V 


Applied Input 
Voltage 
-0.5 to +7.0 V 


Power Dissipation 
1.0 W 


DC CHARACTERISTICS: TA = o to +10 c, vcc = s v 10%, unless otherwise noted. 


CAPACITANCE: TA =-. 25 c, r=1.o MHZ 
$vmb~' 
ii 
Condmon 
Cl 
Input Capacitance 
— 
VOUT = 0 V, Note 


CO 
Output Capacitance _ 
VOUT = 0 V, Note 


Note: This parameter is periodically sampled only. 
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FEATURES 
Controls 8086 CPU speed at 8 MHz 
or 10 MHz 


Generates programmable fast and 
normal timing for memory and VO 


Supports 256k- or 1M-bit DRAMS 


Supports up to 8M bytes of additional 
memory 


Arbitrates the system bus among the 
CPU, DMA, math coprocessor, and 
DRAM memory refresh cycle 


Provides four channels of DMA as 
well as burst mode 


DESCRIPTION 
The CMOS VL82C031/OTI-031 is the 
System Controller device in the three- 
chip VLSI/OTI PS/2 Model 30-compat- 
lbl6 chip set. the other two devices are 


PS/2 MODEL 30-COMPATIB 


VLSI TECHNOLOGY, n\1c. 
VL82C031/OTI-031 
s/2® MODEL 30-COMPATIBLE SYSTEM CONTROLLER 


O 
the VL82CO32/OTI-032 I/O Controller 
and the VL82C033/OTI-033 Floppy 
Disk Controller and Data Separator. 


The chip set integrates logic and 
functions on PS/2 Model 30-compat- 
ible systems to the point of reducing 
the printed circuit board device count 
by half, when memories are excluded. 
Further, while offering complete 
compatibility with the PS/2 Model 30- 
compatible system, the VLSI/OTI chip 
set improves system performance by 
allowing 10 MHz operation with no 
"wait states” (using 150 ns DRAMS), 
supports an additional 8M-bytes of 
memory using EMS (Expanded 
Memory Specification) 4.0, and 
controls system speed as necessary 
for optimum performance. 


A fourth device, the VL82C037/OTI-037 
VGA Video Graphics Controller is also 
used in the PS/2 Model 30-compatible 
system and provides high resolution 
graphics of 800 x 600 elements with 256 
colors. Graphic capabilities of this 
resolution are usually found only on 
more expensive systems. 


The VL82C031/OTI-031 provides the 
PS/2 Model-30 compatible system with 
the dual speed control, 8 MHz or 10 
MHz, necessary to operate the system at 
peak performance. The device also 
controls memory, I/O, parity, address 
paths, data paths as well as handling 
four channels of direct memory access. 
The VL82C031/OTI-031 is available from 
both VLSI Technology Inc. and Oak 
Technology, Inc. in an industry-standard 
plastic 100 pin flat pack. 
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® VLSI TECHNOLOGY, INC. 
VL82CO32/OTI-032 


IBM PS/2® MODEL 30-COMPATIBLE I/O CONTROLLER 


FEATURES 
- Controls Model 30-compatible system 
keyboard and mouse 


- Integrates the following functions on a 
single device: 
-8253-compatible timer/counter 
-Dual 8250-compatible serial com- 
munications controller 
-Parallel port controller 
-8259-compatible interrupt controller 
-5816?-compatible real-time clock 


- Decodes subsystems for floppy disk, 
hard disk, and video 


- Provides chip select logic for seriall 
parallel ports, disk controllers, video 
controllers, and real time clock. 


DESCRIPTION 
The CMOS VL82CO32/OTI-032 is the 
Input/Output Controller device in the 
three-chip VLSI/OTI PS/2 Model 30- 


compatible chip set. the other two 
devices are the VL82C031/OTI-031 
System Controller and the VL82C033/ 
OTI-033 Floppy Disk Controller and 
Data Separator. 


The chip set integrates logic and 
functions on PS/2 Model 30-compat- 
ible systems to the point of reducing 
the printed circuit board device count 
by half, when memories are excluded. 
Further, while offering complete 
compatibility with the PS/2 Model 30- 
compatible system, the VLSI/OTI chip 
set improves system performance by 
allowing 10 MHz operation with no 
“wait states” (using 150 ns DRAMS), 
supports an additional 8M-bytes of 
memory using EMS (Expanded 
Memory Specification) 4.0, and 
controls system speed as necessary 
for optimum performance. 


A fourth device, the VL82C037/OTI-037 
VGA Video Graphics Controller is also 
used in the PS/2 Model 30-compatible 
system and provides high resolution 
graphics of 800 x 600 elements with 256 
colors. Graphic capabilities of this 
resolution are usually found only on 
more expensive systems. 


The VL82CO32/OTI-032 provides the 
PS/2 Model-30 compatible system with 
control of boththe keyboard and the 
pointing device ("mouse”), control of two 
serial communication channels, a real- 
time clock, as well as controlling both the 
disk storage and display functions. It also 
provides the chip select logic for the 
functions it controls. The VL82CO32! 
OTI-032 is available from both -VLSI 
Technology Inc. and Oak Technology, 
Inc. in an industry-standard plastic 100 
pin flat pack. 
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IBM PS/2® is a registered trademark of IBM Corp. 
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® VLSI TECHNOLOGY, INC. 


IBM PS/2® MODEL 30-COMPATIBLE FLOPPY DISK CONTROLLER 


FEATURES 


~ Provides a p.PD765A-COlTlpallDl8 
floppy disk controller 


- Contains a precision analog data 
separator 


~ Integrates an internal phase compara- 
tor, and voltage controlled oscillator 
(VCO) 


- Provides the system with three data 
rates: 
-250K bits-per-second 
—30OK bits-per-second 
-500K bits-per-second 


DESCRIPTION 
The VL82C033/OTI-033 is the Floppy 
Disk Controller and Data Separator 
device in the three-chip VLSI/OTI PS/2 
Model 30-compatible chip set. the other 
two devices are the VL82C031/OTI-031 
System Controller and the VL82C032/ 


PS/2 MODEL 30-COMPATIBLE SYSTEM DIAGRAM 


I/O CHANNEL (PC BUS) 


OTI-032 I/O Controller. 


The chip set integrates logic and 
functions on PS/2 Model 30-compatible 
systems to the point of reducing the 
printed circuit board device count by 
half, when memories are excluded. 
Further, while offering complete 
compatibility with the PS/2 Model 30- 
compatible system, the VLSI/OTI chip 
set improves system performance by 
allowing 10 MHz operation with no “wait 
states” (using 150 ns DRAMS), sup- 
ports an additional 8M-bytes of memory 
using EMS (Expanded Memory 
Specification) 4.0, and controls system 
speed as necessary for optimum 
performance. 


A fourth device, the VL82C037/OTI-037 
VGA Video Graphics Controller is also 
used in the PS/2 Model 30-compatible 
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system and provides high resolution 
graphics of 800 x 600 elements with 
256 colors. Graphic capabilities of this 
resolution are usually found only on 
more expensive systems. 


The VL82C033/OTI-033 provides the 
PS/2 Model-30 compatible system with 
a DPD 765A-compatible floppy disk 
controller function, a precision analog 
data separator, an internal phase 
comparator, the required filters, as well 
as a voltage controlled oscillator (VCO). 
The VL82C033/OTI-033 provides the 
system with three floppy disk data rates: 
250K bits-per-second, 300K bits-per- 
secxand, and 500K bits-per-second. The 
VL82C033/OTI-033 is available from 
both VLSI Technology Inc. and Oak 
Technology, Inc. in an industry-standard 
plastic 48 pin DIP. 
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Notes: Operating temperature range is 0°C to +70°C. 
IBM PS/2® is a registered trademark of IBM Corp. 
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VLSI TECHNOLOGY INC. 
N 
. 
VL82C037/OTI-O37 


FEATURES 


~ Single-chip VGA video graphics 
device that is completely compatible 
in the following systems: 
-IBM PC/AT-compatible 
—lBM PC/XT-compatible 
—lBM PS/2-compatible 


- Full compatible with IBM VGA in all 
Y 
modes 


- Fully compatible with IBM basic inputl 
output system (BIOS) 


- Provides 800 x 600 element high- 
resolution graphics with 256 colors 


~ Flicker-free operation in all video 
modes 


IBM VGA®-COMPATIBLE VIDEO GRAPHICS CONTROLLER 


DESCRIPTION 
The VL82C037/OTI-037 VGA-compat- 
ible Video Graphics Controller is a 
single-chip, high-integration, high 
resolution graphics device intended for 
use in IBM PS/2® Model 30-compat- 
ible systems as well PC/AT- and PCI 
XT-compatible systems. It provides 
high resolution graphics of 800 x 600 
elements with 256 colors. 


The VL82C037/OTI-037 is fully com- 
patible with IBM VGA in all modes, as 
well as being fully compatible with 
Hercules graphics. VL82C037/OTI-037 
compatibility also extends to IBM EGA 
BlOS® (basic input/output system), 


~ Hardware mouse cursor feature 


CGA and MDA. The VL82C037/OTI-037 
automatically switches among the CGA, 
MDA. and Hercules graphic protocols. 


The VLS VOTI VGA-compatible device 
allows split-screen operattion with 
independent scrolling and panning. It is 
also flicker-free in all modes. It supports 
an external digital-to-analog lockup table 
as well as additional video memory for 
high resolution operation with 256 colors. 
The VL82C037 is available from both 
VLSI Technology Inc. and Oak Technol- 
ogy, Inc. in an industry-standard plastic 
100 pin flat pack. 
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FEATURES 
Fully compatible with IBM PC/AT-type 
designs 


Replaces 19 logic devices 


Supports 12 MHz processor clock 


Device is available as "cores" for 
user-specific designs 


Seven DMA channels 


14 external interrupt requests 


Three timer/counter channels 


Designed in CMOS for low power 
consumption 
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VLSI TECHNOLOGY, INC. 
VL82C10O 


PC/AT-COMPATIBLE PERIPHERAL CONTROLLER 


DESCRIPTION 
The VL82C10O PC/AT-Compatible 
Peripheral Controller replaces two 
82C37A Direct Memory Access 
Controllers, two 82C59A Interrupt 
Controllers, an 82054 Programmable 
Counter, a 74LS612 AT Memory 
Mapper, two 74ALS573 Octal Three- 
State Latches, a 74ALS138 3-to-8 
Decoder, and five other less-complex 
integrated circuits. Using this internal 
functionality, the VL82C10O provides all 
24 address bits for 16M bits of DMA 
address space. It also interfaces 
directly to the CPU to handle all 


interrupts. Timing for refresh cycles, 
and arbitration, between refresh and 
DMA hold requests, are also controlled 
by the VL82C100. 


The device is manufactured with VLSl’s 
advanced high-performance CMOS 
process and is available in JEDEC- 
standard 84-pin plastic leaded chip 
carrier (PLCC) package. The 
VL82C10O is individually available, or 
may be purchased as part of the 
' 
complete five-device IBM PC/AT- 
compatible kit. 
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designs 


- Replaces 36 integrated circuits on the 
PC/AT-type board 


- Supports 12 MHz processor clock 


- Device is available as “cores” for 
user-specific designs 


- Sink 20 mA on slot driver outputs 


- Designed in CMOS for low power 
consumption 


Fully compatible with IBM PC/AT-type 


VLSI TECHNOLOGY, INC. 
VL82C101A 


PC/AT-COMPATIBLE SYSTEM CONTROLLER 


FEATURES 
, 
DESCRIPTION 
The VL82C101A PC/AT-Compatible 
System Controller replaces an 82C284 
Clock Controller and 82C288 Bus 
Controller (both are used in ‘286-based 
systems), an 82C84A Clock Generator 
and Driver, two PAL16L8 devices (used 
for memory decode), and approximately 
ten other less cxamplex integrated 
circuits used as Wait State logic. When 
used in 12 MHz systems utilizing 80 ns 
DRAMs, the device provides the 
required one wait state for a "write" 
operation, and zero wait states for a 
"read" operation. A 12 MHz system 
using 120 ns DRAMs will be provided 
with one wait state for “write” and one 


wait state for "read". The device 
accepts both the 24 MHz crystal to 
control the system clock as well as the 
14.318 MHz crystal to control the video 
clock. It also supplies reset and clock 
signals to the I/O slots. 


The device is manufactured with VLSl’s 
advanced high-performance CMOS 
process and is available in a JEDEC- 
standard 84-pin plastic leaded chip 
carrier (PLCC) package. The 
VL82C101A is individually available, or 
may be purchased as part of the 
complete five-device IBM PC/AT- 
compatible kit. 
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ORDER INFORMATION 


Part 
Number 
Package 


VL82C101A-QC 
Plastic Leaded Chip 
Carrier (PLCC) 


Note: Operating temperature is 
0°C to +70°C 


PLEASE CONSULT PC/AT- 
COMPATIBLE USERS 
MANUAL FOR DETAILED 
INFORMATION 


® VLSI TECHNOLOGY, INC. 
VL82C102A 


FEATURES 
- Fully compatible with IBM PC/AT-type 
designs 


- Completely performs memory control 
function in IBM PC/AT-compatible 
systems 


- Replaces 20 integrated circuits on 
PC/AT-type motherboard 


- Support 12 MHz processor clock 


- Device is available as "cores" for 
user-specific designs 


- Designed in CMOS for low power 
consumption 


PC/AT-COMPATIBLE MEMORY CONTROLLER 


DESCRIPTION 
The VL82C102A PC/AT-Compatible 
Memory Controller generates the row 
address strobe (RAS) and column 
address strobe (CAS) necessary to 
support the dynamic RAMs used in PC/ 
AT-type systems. In addition, the 
device allows five motherboard memory 
options for the user, up to a full 4M-byte 
system. Four of the five options allow a 
full 640k-bytes user area to support the 
disk operating system (DOS). In 
addition, the VL82C102A provides the 
upper addresses to the VO slots, the 
chip select for the ROM and RAM 


memory, and drives the system's 
speaken 


The device is manufactured with VLSl’s 
advanced high-performance CMOS 
process and is available in a JEDEC- 
standard 84-pin plastic leaded chip 
carrier (PLCC) package. The 
VL82C102A is individually available, or 
may be purchased as part of the 
complete five-device IBM PC/AT- 
compatible kit. 
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VL82C102A-QC 
Plastic Leaded Chip 
Carrier (PLCC) 


Note: Operating temperature range is 
0°C to +70°C 


PLEASE CONSULT PC/AT- 
COMPATIBLE USERS 
MANUAL FOR DETAILED 
INFORMATION 
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N VLSI TECHNOLOGY, mc. 
VL82C103 


FEATURES 
- Fully compatible with IBM PC/AT-type 
designs 


- Completely performs address buffer 
function in IBM PC/AT-compatible 
systems 


- Replaces several buffers, latches and 
other logic devices 


- Supports 12 MHz processor clock 


- Device is available as “cores” for 
user-specific designs 


- Designed in CMOS for low power 
consumption 
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DESCRIPTION 
The VL82C103 PC/AT-Compatible 
Address Buffer provides the system 
with _a 16-bit address bus input from the 
CPU to 41 buffered drivers. The 
buffered drivers consist of 17 bidirec- 
tional system bus drivers, each capable 
of sinking 20 mA (50 ‘LS loads) of 
current and driving 200 pF of capaci- 
tance on the backplane; 16 bidirectional 
peripheral bus drivers, each capable of 
sinking 8 mA (20 ‘LS loads) of current; 
and eight memory bus drivers, also 
capable of sinking 8 mA of current. On- 
chip refresh circuitry supports both 
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256K-bit and 1M-bit DRAMs. The 
VL82C103 provides addressing for the 
I/O slots as well as the system. 


The device is manufactured with VLSl’s 
advanced high-performance CMOS 
process and is available in a JEDEC- 
standard 84-pin plastic leaded chip 
carrier (PLCC) package. The 
VL82C103 is individually available, or 
may be purchased as part of the 
complete five-device IBM PC/AT- 
compatible kit. 


ORDER INFORMATION 


Part 
Number 
Package 


VL82C103-QC 
Plastic Leaded Chip 
Carrier (PLCC) 


Note: Operating temperature range is 
0°C to +70°C 


PLEASE CONSULT PC/AT- 
COMPATIBLE USERS 
MANUAL FOR DETAILED 
INFORMATION 


N VLSI TECHNOLOGY, INC. 
VL82C1 04 


FEATURES 


~ Fully cxampatible with IBM PC/AT-type 
designs 


- Completely performs data buffer 
function in IBM PC/AT-compatible 
systems 


- Replaces several buffers, latches and 
other logic devices 


- Supports 12 MHz processor clock 


- Device is available as “cores” for 
user-specific designs 


- Designed in CMOS for low power 
consumption 
I 


PC/AT-COMPATIBLE DATA BUFFER 


DESCRIPTION 
The VL82C104 PC/AT-Compatible Data 
Buffer provides a 16-bit CPU data bus 
I/O as well as 40 buffered drivers. The 
buffered drivers consist of 16 bidirec- 
tional system data bus drivers, each 
capable of sinking 20 mA (50 ‘LS loads) 
of current; eight bidirectional peripheral 
bus drivers, each capable of sinking 8 
mA (20 ‘LS loads) of current; and 16 
memory data bus drivers, each capable 
of sinking 8 mA (20 ‘LS loads) of 
current. The VL82C104 also generates 
the parity error signal for the system. 


The device is manufactured with VLSl's 
advanced high-performance CMOS 
process and is available in a JEDEC- 
standard 84-pin plastic leaded chip 
carrier (PLCC) package. The 
VL82C104 is individually available, or 
may be purchased as part of the 
complete five device IBM PC/AT- 
compatible kit. 


BLOCK DIAGRAM 
ORDER INFORMATION 
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XMEMR 


Part 
Number 
Package 


VL82C104-QC 
Plastic Leaded Chip 
Carrier (PLCC) 


Note: Operating Temperature range is 
0°C to +70°C 


PLEASE CONSULT PC/AT- 
COMPATIBLE USERS 
MANUAL FOR DETAILED 
INFORMATION 
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12 MHZ AND 16 MHZ PC/AT-COMPATIBLE SYSTEM CHIP SETS 
FEATURES 
DESCRIPTION 
I 
- Fully compatible with IBM PC/AT-type 
The IBM PC/AT compatible chip set 
consistent with economic and reliable 
designs 
from VLSI Technology, lnc. supports 1- 
system design. The VL82C103 
Megabit dynamic RAMs, and is utilized 
Address Buffer and VL82C104 Data 
in systems with clock speeds up to 12 
Buffer are offered in separate pack- 
- Reduces non-memory system device 
MHz. The chip set provides the IBM 
ages, although their circuit is relatively 
Count from 11010 16 
PC/AT compatible system with a 
small. If they were offered as a single 
completely compatible low-cost board 
device, the pin count would be ex- 
design solution. Further, since the 
tremely high, or some performance 
devices were designed using VLSl’s 
degradation would occur. 
’ A" devices d9$I9_"°d In CMQ5 IOF IOW 
design tools, the devices can be quickly 
P°W°f ¢°"$UmPI|°" 
modified for use as cores in user- 
VLSPS advanced high_peormance 


° SUPPQFIS 12 MHZ Pf°°9$$0f ¢I°°I< 
Specic designs‘ 
CMOS process and all five are available 
. 15 MHZ version of chip set with page 
The_five device chip set has been 
. 
in a JEDEC-standard 84-pin plastic 
designed using the highest integration 
leaded chip carrier (PLCC) package. 


' High-integration five-chip set 


' Devices are available as "cores” for 
user-specific designs 


The devices are manufactured with 


mode memory access will be avail- 
able in 1988 
BLQCK [MAGRAM 
MOTHERBOARD BLOCK DIAGRAM 


DATA 


LOWER ADDRESS 


80287 
80286 


FLOATING n 
CPU 
POINT 
VL82C103 
VL82C104 
COPROCESSOR 
ADDRESS 
DATA 


UPPER ADDRESS 


VL82C1M 
- 


PERIPHERAL 
CONTROLLER 


8042 
V0 SLOTS 
4 
4 
$55 
“E*B°”‘° "°’ 
M 
CONTROL 
UPPER 
_m‘__ 
ADDRESSES 
UPPER ADDRESSES 


BATTERY AND 
“MHZ 
VL82C102 
non CHIP SELECT 
I 
I 
OSCILLATOR 
|:I 
MEMORY‘iigE l|'l||IIIIII'1I% 
SELECT 
CONTROLLER 
A~0 
VL82C101 
U 
REFRESH 
STF‘°BES 


CLOCK AND CONTROL TO 80286 
14.318 
SYSTEM 
MHz 
CLOCK AND corrrnot TO ao2a7 
CONTROLLER 
I 
M 
I 
CLOCK mo RESET 
SPEAKER 
@_ 
TO SLOTS 
I 


|-|—|—n:|§_ 
PLEASE CONSULT THE 
PC/AT-COMPATIBLE CHIP 
EQDER lNF0I:,:::‘TloN 
SET USERS MANUAL FOR 
Numbe, 
package 
DETAILED INFORMATION: 
VL82CPCAT-QC 
12 MHz 
(5 Chips) Plastic Leaded Chip Carrier (PLCC) 
VI-32CPCAT (12 MHZ) 
VL82CPCPM-Q 
16 MHZ 
(6 Chips) Plastic Leaded Chip Carrier (PLCC) 
VL82CPCPM 16 MH 
( 
Z) 
Note: Operating temperature range is 0°C to +70°C 
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VL82C284 


FEATURES 


- Generates clock for Intel 286-type 
microprocessor-based systems 


- External TIL source or crystal may be 
used as frequency source 
- On-board crystal oscillator 


- Provides Local -READY signal for 
system synchronization 


- Generates system reset 


- Schmitt-trigger reset input assures 
stability and noise immunity 


- Low power consuming CMOS 
technology 


CMOS CLOCK GENERATOR AND INTERFACE 


DESCRIPTION 
The VL82C284 is a clock generator and 
driver that provides clock and interlace 
signals to Intel 286-type microproces- 
sor-based systems. All device output 
signals are synchronized to the output 
clock signal. 


The clock input and output frequencies 
are twice the frequency used internally 
by the microprocessor in the system. 
To avoid confusion, the clock frequency 
in the order information represents the 
internal system microprocessor clock 
frequency (e.g., the devices listed as 8 
MHz would actually have an input 


crystal or a TTL signal frequency of 16 
MHz). 


The VL82C284 also supplies the 
system with a high-noise-immunity 
reset, as well as a synchronous 
peripheral clock and a synchronous 
--READY to indicate the completion of 
the current bus cycle. 


The peripheral clock is controlled by two 
status input signals, which may be left 
open if not used. 


The VL82C284 is available in an 18-pin 
ceramic and plastic DIP, as well as in a 
plastic leaded chip carrier. 


PIN DIAGRAM 


VL82C284 


-ARDY 
1 
-SRDY I 2 
-SRDYEN I 3 
-READY I 4 


EFI I 5 
F/-C I 6 


X1 I 7 


X2 I 8 
GND I 9 


18 I VCC 


17 I —ARDYEN 
16lI 
S1 
15lI S0 
VII NIL 


13 I 
PCLK 


12 I RESET 


11 I -RES 


10 I CLK 


PLEASE CONSULT DATA 
SHEET FOR DETAILED 
INFORMATION 


BLOCK DIAGRAM 


X2 
OSCILLATOR 
w 
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RESET 
X' 
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PCLK 
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CLK 
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-SRDY 
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ORDER INFORMATION 


Part 
Clock 
Number 
Frequency 
Package 


VL82C284-08PC 
Plastic DIP 
VL82C284-08OC 
8 MHZ 
Plastic Leaded Chip Carrier (PLCC) 
VL82C284-08CC 
Ceramic DIP 
VL82C284-10PC 
Plastic DIP 
VL82C284-10OC 
10 MHz 
Plastic Leaded Chip Carrier (PLCC) 
VL82C284-10CC 
Ceramic DIP 


Note: Operating temperature range is 0°C to+70°C. 
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FEATURES 
DESCRIPTION 
- 
Both local and system bus oom- 
The VL82C288 is a CMOS bus control- 
mands and control are provided 
ler for use in Intel 286-type microproces- 


- 
- 
-based systems. A mode select pin 
- 
Supports both Mult|bus° and h|gh- 
sor 
. 
. 
. 
. 
ll 
d 


’ 
HI9h'¢U"°m QUIPUI dfiV9f$ 
device also provides separate command 
outputs tor memory and I/O devices. 


VLSI TECHNOLOGY, mc. 


- 
Flexible command timing 


exibility 


- 
Single 5 V power supply 


PIN DIAGRAM 


-READY 
CLK 
-s1 
MCE 
ALE 
MB 
CMDLY 
-MRDC 
-MWTC 
GND 


VL82C288 


20 I vcc 


19 I -so 


1e I M/-IO 
17 I DT/-R 


16 I DEN 


15 I CEN/—AEN 


14 I CENL 


13 I -INTA 
I 9 
12 I -IORC 
10 
11 I -IOWC 


1 
2 
3 
4 
5 
6 
7 
8 


PLEASE CONSULT DATA 
SHEET FOR DETAILED 
INFORMATION 


_ 
_ 
_ 
The data bus is controlled by separate 
' 
High d°9'°° °I $Y$T°m ¢°"I'9l-"aI'°" 
data direction anddata enable signals. 


_ 
A system clock provides the timing 
' 
I-OW Power. °°"$"m'"9 CMQ3 
oontrol required by the microprocessor- 
I°¢h"°|°9Y 
based system. The device clock input is 


BLOCK DIAGRAM 
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ORDER INFORMATION 


COM- 
MAND 
OUTPUT 
LOGIC 


CONTROL 
OUTPUT 
LOGIC 


Part 
Clock 
Number 
Frequency 
Package 


VL82C288-06PC 
VL82C288-OBQC 
VL82C288-06CC 
VL82C288-08PC 
VL82C288-OBQC 
VL82C288-08CC 


VL82C288 
CMOS BUS CONTROLLER 


STATE 
MACHINEi 


Plastic DIP 


twice the system clock speed. To avoid 
confusion, the clock frequency listed in 
the order information is the system clock 
frequency (e.g., the devices listed as 8 
MHz Clock Frequency, would have an 
input clock of 16 MHz). 


The VL82C288 meets the timing and 
drive requirements to satisfy the lEEE- 
796 standard for Multibus. 


The VL82C288 is available in a 20-pin 
ceramic or plastic DIP, as well as in a 
plastic leaded chip carrier. 


STATUS 
<---—- -so 
STATUS 
oscooen ‘—-i“ '3‘ 
4———--i IW-IO 


CLK 
<——--Ms 
-READY 


CQNTRQL 
CEN/—AEN 


LOGIC 
CMDLY 


6 MHz 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 
Plastic DIP 
8 MHz 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 


Note: Operating temperature range is 0°C to +70°C. 


Multibus° is a registered trademark of Intel Corp. 
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VL82C37A 
CMOS DIRECT MEMORY ACCESS (DMA) CONTROLLER 


FEATURES 
- Low-power CMOS version of popular 
8237A DMA controller 


- Four DMA channels 


- Individual enable/disable control of 
DMA requests 


- Directly expandable to any number of 
channels 


- Independent auto-initialize feature for 
all channels 


- High performance 8 MHz version 
available 


- Transfers may be terminated by end- 
of-process input 


- Software controlled DMA requests 


- Independent polarity control for 
DREQ and DACK signals 


DESCRIPTION 
The VL82C37A Direct Memory Access 
(DMA) Controller serves as a peripheral 
interface circuit for microprocessor 
systems, and is designed to improve 
system performance by allowing 
external devices to directly transfer 
information from the system memory. 
Memory-to-memory transfer capability is 
also provided. The VL82C37A DMA 
Controller offers many programmable 
control features that enhance data 
throughput and system performance. 
Dynamic reconfiguration is permitted 
under program control. 


The VL82C37A is designed to be used 
with an external 8-bit address register 


such as the 8282. In addition to the four 
independent channels, the VL82C37A is 
expandable to any number of channels 
by cascading additional controller 
devices. 


Three basic transfer modes allow the 
user to program the types of DMA 
service. Each channel can be individu- 
ally programmed to auto-initialize to its 
original condition following an end-of- 
process (EOP) input. Each channel also 
has a 64K address and word count 
handling ability. 


The VL82C37A DMA Controller is 
available in 5 MHz and 8 MHZ clock 
frequencies. 


PIN DIAGRAM 


VL82C37A 


—|OR I 1 
40 I A7 
-IOW I 2 
39 I A6 
-MEMR I 3 
38 I A5 
—MEMW I 4 
37 I A4 
VCC I 5 
36 I —EOP 
READY I 6 
35 I A3 
HLDA I 7 
34 I A2 
ADSTB I 8 
33 I A1 
AEN I 9 
32 I 


CLK I 12 
29 I 
13 
28 


BLOCK DIAGRAM 
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neoussr <4) 


ORDER INFORMATION 


k 
Part 
Number 
VL82C37A-OSPC 
VL82C37A-OSCC 
VL82C37A-OSQC 
VL82C37A-08PC 
VL82C37A-08CC 
VL82C37A-08QC 


5 MHz 


8 MHz 


Cloc 
Frequency 
Package 
Plastic DIP 
Ceramic DIP 
Plastic Leaded Chi Carrier PLCC 
Plastic DIP 
Ceramic DIP 
Plastic Leaded Chip Carrier (PLCC) 
Note: Operating temperature range is 0°C to +70°C. 
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PIN DIAGRAM 


® VLSI TECHNOLOGY, mc. 
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SIGNAL DESCRIPTIONS 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


CLK 
12 
Clock Input: Controls the internal operations of the VL82C37A DMA Controller and its rate 
of data transfers. This input may be driven at up to 4 MHz for the standard VL82C37A-04 
and up to 8 MHz for the VL82C37A-08. 
-C3 
11 
Chip Select: An active low input used to select the VL82C37A as an I/O device during the 
idle cycle, allows CPU communication on the data bus. 


RESET 
13 
Reset: An active high input that clears the Command, Request, and Temporary Registers, 
clears the first/last flip-flop, and sets the Mask Register. The device is in the idle cycle 
following a Reset signal. 


READY 
6 
Ready: An input that extends the memory read and write pulses from the VL82C37A 
accommodating slow memories or l/O peripheral devices. During its specified setup/hold 
time, READY must not make transitions. 


HI-DA 
7 
Hold Acknowledge: This active high signal from the CPU indicates that it has relinquished 
control of the system busses. 


DREQO-DREQ3 
19 - 16 
DMA Request: These lines are individual asynchronous channel request inputs. Periph- 
eral circuits use these lines to obtain DMA service. In fixed Priority, DREQO has the 
highest priority and DREQ3 has the lowest priority. Activating the DREQ line of a channel 
generates a request. DACK then acknowledges the recognition of DREQ signal. Polarity 
of DREQ is programmable. Reset initializes these lines to active high. DREQ must be 
sustained until the corresponding DACK becomes active. 


DBO - DB7 
30 - 26, 
Data Bus: These lines are bidirectional, three-state signals that connect to the system 
23 - 21 
data bus. The outputs are enabled in the program condition during the I/O read to output 
the contents of an Address Register, a Status Register, the Temporary Register, or a 
Word Count Register to the CPU. The outputs are disabled and the inputs are read during 
an l/O Write cycle when the CPU is programming the VL82C37A control registers. During 
DMA cycles the most significant eight bits of the address are sent onto the data bus and 
are strobed into an external latch by ADSTB. In memory-to-memory operations, data from 
the memory comes into the VL82C37A on the data bus during the read-from-memory 
transfer. In the write-to-memory transfer, the data bus outputs determine the placement of 
the data, not the new memory location. 
' 


-IOR 
1 
I/O Read: This is a bidirectional, active low, three-state line. In the idle cycle, it is an input 
control signal used by the CPU to read the control registers. In the active cycle, it is an 
output control signal used by the VL82C37A to access data from a peripheral during a 
DMA Write transfer. 
-IOW 
2 
I/O Write: This signal is a bidirectional active ow, three-state line. It is used by the CPU to 
load information into the VL82C37A DMA Controller. In the active cycle, it is used as an 
output control signal used by the VL82C37A to load data to the peripheral during a DMA 
read transfer. 


-EOP 
36 
End of Process: This is an active low bidirectional signal, which provides data on the 
completion of DMA services and is available at the bidirection -EOP pin. The VL82C37A 
allows an external signal to terminate an active DMA service, by pulling the —EOP input 
low with an external -EOP signal. The VL82C37A also generates a pulse when the 
terminal count (TC) for any channel is achieved. This generates an -EOP signal that is 
active on the -EOP Line. When -EOP is received, either internally or externally, it will 
cause the VL82C37A to terminate the service, reset the request, and, if auto-initialize is 
enabled, to write the base registers to the current registers of that channel. The mask bit 
and TC bit in the status word will be set for the currently active channel by —EOP, unless 
the channel is programmed for auto-initialize. In that case, the mask bit remains un- 
changed. During memory-to-memory transfers, -EOP will be output when the TC for 
channel 1 occurs. To prevent erroneous end-of-process inputs, -EOP should be tied 
high with a pull-up resistor if it is not used. 
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SIGNAL DESCRIPTIONS (CONT.) 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


A0 - A3 
32 - 35 
The four least significant address lines: These lines are bidirectional three-state signals. 
In the idle cycle, they are inputs used by the CPU to address the register to be loaded or 
read. In the active cycle they are outputs that provide the lower four bits of the output 
address to the system. 


A4 - A7 
37 - 40 
The four most significant address lines: These lines are three-state outputs that provide 
four bits of address. They are enabled only during the DMA service. 


HRQ 
10 
Hold Request: This is the hold request to the CPU. It is used to request control of the 
system bus. If the corresponding mask bit is clear, the presence of any valid DREQ 
causes the VL82C37A to issue the HRQ signal. After HRQ is asserted, at least one clock 
cycle (TCY) must occur before HLDA can be valid. 


DACKO - DACK3 
25, 24, 14, 
DMA Acknowledge: This signal is used to notify an individual peripheral when it has been 
15 
granted a DMA cycle. The sense of these lines is programmable; Reset initializes them to 
an active low. 


AEN 
9 
Address Enable: This active high line enables the 8-bit latch containing the upper eight 
address bits onto the system address bus. It can also be used to disable other system 
bus drivers during DMA transfers. 


ADSTB 
8 
Address Strobe: This active high is used to strobe the upper address byte into an external 
latch. 
-MEMR 
3 
Memory Read: This active low signal is a three-state output used to access data from a 
selected memory location during a DMA read or memory-to-memory transfer. 


—MEMW 
4 
Memory Write: This signal is an active low three-state output used to write data to a 
selected memory location during a DMA write or memory-to-memory transfer. 


VCC 
5, 31 
+5 V :t5% power supply. 


GND 
20 
Ground. 


TABLE 1. INTERNAL REGISTERS 


' 
4 
Base Address Registers 
16 bits 


Base Word Count Registers 
16 bits 
4 


Current Address Registers 
16 bits 
4 


Current Word Count Registers 
16 bits 
4 


Temporary Address Register 
16 bits 
1 


Temporary Word Count Register 
16 bits 
1 


Status Register 
8 bits 
1 


Command Register 
8 bits 
1 


Temporary Register_ 
8 bits 
1 


Mode Registers 
6 bits 
4 


Mask Register 
4 bits 
1 


Request Register 
4 bits 
1 
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FUNCTIONAL 
DESCRIPTION 
The internal registers and major logic 
blocks of the VL82C37A are shown in 
the block diagram. Data interconnection 
paths are also shown, but the various 
control signals between the blocks are 
not. The VL82C37A contains 344 bits of 
internal register memory. Figure 3 
describes these registers and shows 
them by size. A complete description of 
the registers and their functions can be 
found in the Register Descriptions 
secon. 


The VL82C37A contains three basic 
control logic blocks. The Timing Control 
block generates internal timing and 
external control signals for the 
VL82C37A. The program command 
control block decodes the various 
commands given to the VL82C37A by 
the microprocessor before servicing a 
DMA Request. Further, it decodes the 
mode cxantrol word used to select the 
type of DMA during the servicing. The 
priority encoder block settles priority 
contention between DMA channels 
requesting service at the same time. 


The external clo_ck drives the timing 
control block. In most VL82C37A 
systems, this clock will usually be the 
Q52 TTL clock from an VL82C84A. For 
8085AH-2 systems above 3.9 MHz, the 
8085 CLK(OUT) will not meet 
VL82C37A-05 (5 MHz) clock low and 
high time requirements. In this case, an 
external clock should be used to drive 
the VL82C37A-05. 


DMA OPERATION 
The VL82C37A is designed to operate 
in two major cycles: the idle and active . 
Several states are contained in each 
device cycle. The VL82C37A supports 
seven separate states, each being one 
full clock period. State I (SI), the 
inactive state, is entered when the 
VL82C37A has no valid DMA requests 
pending. While in SI, the DMA controller 
is inactive but may be in the program 
condition, being programmed by the 
processor. State 0 (S0) is the first state 
of a DMA service. The VL82C37A has 
requested a hold, but the processor has 
not yet responded with an acknowledge. 
The VL82C37A may still be pro- 
grammed until it receives HLDA from the 
CPU. An acknowledge from the CPU 


signals that DMA transfers may begin. 
S1, S2, S3 and S4 are the functional 
states of the DMA service. If more time 
is needed to complete a transfer than is 
available with normal timing, wait states 
(WS) can be placed between S2 or S3 
and S4 by using the Ready line on the 
VL82C37A. The data is transferred 
directly from the I/O device to memory 
(or vice versa) with -IOR and —MEMW 
(or -MEMR and -IOW) being active si- 
multaneously. The data is not read into 
or driven out of the VL82C37A during 
I/O-to-memory or memory-to-l/O DMA 
transfers. 


To complete memory-to-memory 
transfers requires a read-from and a 
write-to-memory. The states, which 
resemble the normal working states, use 
two-digit numbers for identification. 
Eight states are needed for each 
transfer: the first four states (S11, S12, 
S13, S14), are used for read-from- 
memory and the last four states (S21, 
S22, S23, S24), for the write-to-memory 
of the transfer. 


IDLE CYCLE 
When no channels are requesting 
service, the VL82C37A enters the idle 
cycle and performs Sl states, sampling 
the DREQ lines every clock cycle to 
determine if any channel is requesting a 
DMA service. The device also samples 
—CS, looking for an attempt by the 
microprocessor to write or read to the 
internal registers of the VL82C37A. 
When -CS is low and HLDA is low, the 
VL82C37A initiates the program 
condition. The CPU now establishes, 
changes or inspects the internal 
definition of the part by reading from or 
writing to the internal register. Address 
lines A0-A3 are inputs to the device. 
They select registers that will be read or 
written. The -IOR and -IOW lines are 
used to select and time reads or writes. 
Because of the number and size of the 
internal registers, an internal flip-flop is 
used to generate one more bit of 
address. This bit is used to determine 
the upper or lower byte of the 16-bit 
address and Word Count Registers. 
This flip-flop can be reset by a separate 
software command. 


Special software commands executed in 
the VL82C37A during the program 
condition are decoded as sets of 
addresses with the —CS and -IOW 
signals. The commands do not use the 
data bus. Clear First/Last Flip-Flop and 
Master Clear instructions are included. 


ACTIVE CYCLE 
When the VL82C37A is in the idle cycle 
and a nonmasked channel requests a 
DMA service, the device outputs an 
HRQ to the microprocessor and then 
enters the active cycle. During this 
cycle the DMA service takes place, in 
one of four modes. 


In the single transfer mode, the device is 
programmed to make only one transfer. 
The word count is decremented and the 
address decremented or incremented, 
following each transfer. When the word 
count is completed from zero to FFFFH, 
a Terminal Count (TC) causes an auto- 
initialize if the channel has been so 
programmed. 


The DREQ signal must be held active 
until DACK becomes active, in order to 
be recognized. 
If DREQ is held active 
for the entire single transfer, HRQ will 
become inactive and release the bus to 
the system. It again goes active and, 
upon receipt of a new HLDA, another 
single transfer is performed. In 8080A, 
8085AH, 8088, or 8086 systems this 
insures one full machine cycle execution 
between DMA transfers. Details of 
timing between the VL82C37A and 
other bus wntrol protocols depends 
upon the characteristics of the micropro- 
cessor involved. 


ln the block transfer mode, the device is 
activated by the DREQ signal to 
continue making transfers during the 
service until a TC, caused by word count 
going to FFFFH, or an external end of 
process (-EOP) is encountered. DREQ 
need only be held active until DACK 
becomes active. An auto-initialization 
will occur at the end of the service, if the 
channel has been programmed for it. 


In the demand transfer mode the device 
is programmed to continue making 
transfers until a TC or external -EOP is 
encountered or until the DREQ signal 
goes inactive. Transfers may continue 
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until the I/O device has exhausted its 
data capacity. After the l/O device has 
caught up, the DMA service is re- 
established by a DREQ signal. During 
the interval between services, when the 
microprocessor is operating, the 
intermediate values of address and word 
count are stored in the VL82C37A 
Current Address and Current Word 
Count Registers. Only an -EOP can 
cause an auto-initialize at the end of the 
service. EOP is generated either by TC 
or by an external signal. 


The fourth mode cascades multiple 
VL82C37As together for easy system 
expansion. The HRQ and HLDA signals 
from additional VL82C37As are con- 
nected to the DREQ and DACK signals 
of a channel of the primary VL82C37A. 
This permits the DMA requests of the 
additional device to propagate through 
the priority network circuitry of the 
preceding device. The priority chain is 
not broken, and the new device waits for 
its turn to acknowledge requests. As the 
cascade channel of the primary 
VL82C37A is used only to prioritize the 
additional device, it does not produce 
any address or control signals of its 
own, which could conflict with the 
outputs of the active channel in the 
added device. The VL82C37A responds 
to the DREQ and DACK signal, but all 
other outputs except HRQ are disabled. 


Figure 8 shows two devices cascaded 
into a primary device using two of the 
previous channels. This forms a two- 
level DMA system. More VL82C37A's 
could be added at the second level by 
using the remaining channels of the first 
level. More devices can also be 
cascaded into the channels of the 
second-level devices, forming a third 
level. 


TRANSFER TYPES 
Each of the three modes of active 
transfer can perform three different 
types of transfers: read, write and 
verify. Write transfers move data from 
an I/O device to the memory by activat- 
ing —MEMW and -IOR; read transfers 
move data from memory to an I/O 
device by activating -MEMR and -IOW. 


Verify transfers are pseudo routines: 
the VL82C37A DMA Controller operates 
as in read or write transfers generating 
addresses, and responding to -EOP, 


N 
. 


and other operations.The memory and 
I/O control lines remain inactive. The 
verify mode is not permitted during 
memory-to-memory operation. 


To perform block moves of data from 
one memory address space to another 
with a minimum of programming, the 
VL82C37A includes a memory-to- 
memory transfer feature. Programming 
a bit in the Command Register selects 
channels 0 and 1 to operate as memory- 
to-memory transfer channels. The 
transfer is initiated by setting the 
software DREQ for channel 0. The 
VL82C37A requests a DMA device as 
usual. After HLDA is true, the device, 
using eight-state transfers in block 
transfer mode, reads data from the 
memory. The channel 0 Current 
Address Register is the source for the 
address, and is decremented or 
incremented as usual. The data byte 
read from the memory is then stored in 
the VL82C37A internal Temporary 
Register. Channel 1 writes the data 
from the Temporary Register to memory 
using the address in its Current Address 
Register and incrementing or decre- 
menting it as usual. The channel 1 
current word count is decremented. 
When the word count goes to FFFFH, a 
TC is generated causing an -EOP 
output terminating the service. 


Channel 0 may be programmed to hold 
the same address for all transfers, which 
permits a single word to be written to a 
block o_f memory. 


The VL82C37A responds to external 
-EOP signals during memory-to- 
memory transfers. In block search 
schemes data comparators may use this 
input on finding a match. The timing of 
memory-to-memory transfers is shown 
in Figure 10. Memory-to-memory 
operations can be detected as an active 
AEN signal with no DACK outputs. 


A channel may be set up to auto- 
initialize by setting a bit in the Mode 
Register. During initialization, the 
original values of the Current Address 
and Current Word Count Registers are 
automatically restored from the Base 
Address and Base Word Count Regis- 
ters of that channel following -EOP. 
The base registers and the current 
registers are loaded at the same time. 
They remain unchanged thoughout the 
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DMA service. The mask bit is not set 
when the channel is in auto-initialize. 
Following auto-initialize, the channel is 
prepared to perform another DMA 
service, without CPU action, as soon as 
a valid DREQ is detected. 


The VL82C37A has two types of priority 
encoding available as software-se- 
lectable options. The fixed priority 
option sets the channels in priority order 
based upon the descending value of 
their number. The channel with the 
lowest priority is 3, then 2,1 and the 
highest priority channel is 0. After 
recognizing any one channel for service, 
the other channels are prevented from 
interferring with that service until it is 
completed. 


In the rotating priority option, the last 
channel to get service becomes the 
lowest priority channel with the others 
rotating in order. 


Rotating priority allows a single chip 
DMA system. Any device requesting 
service is guaranteed to be recognized 
after no more than three higher priority 
services have occurred. This prevents 
any one channel from dominating the 
system. 


To achieve even greater throughput 
where system characteristics permit, the 
VL82C37A DMA Controller can com- 
press the transfer time to two clock 
cycles. State S3 is used to extend the 
access time of the read pulse. By 
removing state S3, the read pulse width 
is made equal to the write pulse width, 
and a transfer consists only of state S2 
to change the address and state S4 to 
perform the read/write. S1 state still 
occurs when A8-A15 need updating 
(see the Address Generation section.) 


To reduce pin wunt, the VL82C37A 
multiplexes the eight higher order 
address bits on the data lines. State S1 
is used to output the higher order 
address bits to an external latch, where 
they may be placed on the address bus. 
The falling edge of the Address Strobe 
(ADSTB) is used to load these bits from 
the data lines to the latch. Address 
Enable (AEN) is used to enable the bits 
onto the address bus through a three- 
state enable. The lower order address 
bits are directly sent by the VL82C37A . 
Lines A0-A7 are connected to the 
address bus. 
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During block and demand transfer mode 
services, including multiple transfers, the 
addresses generated will be in order. 
During a large number of transfers the 
data held in the external address latch 
will not change. This data will change 
when a carry or borrow from A7 to A8 
takes place in the normal order of 
addresses. To expedite transfers, the 
VL82C37A DMA Controller executes S1 
states only when needed to update A8- 
A15 in the latch. For long services, S1 
states and address strobes may occur 
only once every 256 transfers, a savings 
of 255 clock cycles for each 256 
transfers. 


REGISTER DESCRIPTION 
Current Address Register: Each channel 
has a 16-bit Current Address Register. 
This register holds the value of the 
address used during DMA transfers. 
The address is automatically incre- 
mented or decremented after each 
transfer and the intermediate values of 
the address are stored in the Current 
Address Register throughout the 
transfer. The microprocessor reads this 
register in successive 8-bit bytes. It may 
also be reinitialized by an auto-initialize 
to its original value which takes place 
only after an —EOP. 


Current Word Register: Each channel 
has a 16-bit Current Word Count 
Register that determines the number of 
transfers to be performed. The actual 
number of transfers is one more than 
the number programmed in the Current 
Word Count Register; programming a 
count of 100 will result in 101 transfers. 
The word count is decremented after 
each transfer; the intermediate value of 
this word count is stored in the register 
during the transfer. When the value in 
the register goes from 0 to FFFFH, a TC 
is generated. The register is then 
loaded or read in successive 8-bit bytes 
by the microprocessor in the program 
condition. Following the end of a DMA 
service, it may also be reinitialized by an 
auto-initialization to its original value 
. 
which occurs only on -EOP. If it is not 
auto-initialized, this register has a count 
of FFFFH after TC. 


Base Address and Base Word Count 
‘ 
Registers: Each channel has a pair of 
16-bit Base Address and Base Word 
Count Registers that store the original 
value of their associated current 


registers. Throughout auto-initialization 
these values are used to restore the 
current registers to their original values. 
The base registers are written at the 
same time with their corresponding 
current register in 8-bit bytes in the 
program condition by the microproces- 
sor. These registers cannot be read by 
the microprocessor. 


Command Register: This 8-bit register 
controls the operation of the VL82C37A, 
is programmed by the microprocessor in 
the program condition and is cleared by 
reset or a master clear instruction. 
Figure 2 lists and describes the function 
of the command bits. 


Mode Register: All channels have a 6-bit 
Mode register. When the register is 
being written to by the microprocessor in 
the program condition, bits 0 to 1 
determine which channel the Mode 
Register is to be written. 


Request Register: The VL82C37A can 
responds to requests for DMA service 
that are initiated by software as well as 
by a DREQ signal. Each channel has a 
request bit associated with it in the 4-bit 
Request Register. These are non- 
maskable and can be prioritized by the 
priority encoder network. 


Each register bit is set or reset sepa- 
rately under software control, or is 
cleared upon generation of a TC or 
external -EOP. The entire register is 
cleared by a Reset. To set or reset a 
bit, the software loads the correct form 
of the data word. Table 2 shows 
register address coding. To make a 
software request, the channel must be in 
block mode. 


Mask Register: Each channel has an 
associated mask bit that can be set to 
disable the incoming DREQ signal. A 
mask bit is set when its associated 
channel produces an -EOP, if the 
channel is not programmed for auto- 
initialize. Any bit of the 4-bit Mask 
register may also be set or cleared 
separately under software control. The 
entire register is set by a reset, which 
disables all DMA requests until a clear 
Mask Register instruction allows them to 
occur. This instruction to separately set 
or clear the mask bits is similar in form 
to that used with the Request Register. 


Status Register: The Status Register is 
available to be read out of the 
VL82C37A DMA Controller by the 
microprocessor and contains information 
about the status of the devices at this 
point. This information includes which 
channels have reached a terminal count 
and which channels have pending DMA 
requests. 


Bits 0-3 are set each time a TC is 
reached by that channel or an external 
-EOP is applied and are cleared upon 
reset and on every status read. Bits 4 
through 7 are set whenever their 
corresponding channel is requesting 
service. 


Temporary Register: The Temporary 
Register is used to hold data during 
memory-to-memory transfers. The last 
word moved can be read by the micro- 
processor in the Program Condition 
following the completion of the transfers. 
The Temporary Register always 
contains the last byte transferred in the 
previous memory-to-memory operation, 
unless cleared by a reset. 


Software Commands: These additional 
special software commands can be 
executed in the program condition and 
do not depend on any specific bit pattern 
on the data bus. 


The clear first/last flip-flop command is 
executed prior to writing or reading new 
address or word count information to the 
VL82C37A. This initializes the flip-flop 
to a known state so that subsequent 
accesses to register contents by the 
microprocessor will address upper and 
lower bytes in the correct sequence. 


The Master Clear software instruction 
has the same effect as the hardware 
reset. The Command, Status, Request, 
Temporary, and Internal First/Last Flip- 
Flop Registers are cleared and the Mask 
Register is set. The VL82C37A enters 
an idle cycle. 


The Clear Mask Register command 
clears the mask bits of all four channels, 
enabling them to accept DMA requests. 


PROGRAMMING 
The VL82C37A DMA Controller accepts 
programming from the host processor 
any time that HLDA is inactive, even if 
the HRQ signal is active. The host must 
assure that programming and HLDA are 
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mutually exclusive. 
A problem can 
occur if a DMA request occurs, on an 
unmasked channel while the VL82C37A 
is being programmed. 


For example, the CPU may be starting 
to reprogram the two-byte Address 
Register of a channel when that 
channel receives a DMA request. If the 


APPLICATION 
Figure 1 shows a convenient method for 
configuring a DMA system with the 
VL82C37A DMA Controller and an 
8080A/8085AH microprocessor system. 
Whenever there is at least one valid 
DMA request from a peripheral device, 
the multimode VL82C37A DMA Control- 
ler issues a HRQ to the processor. 


FIGURE 1. SYSTEM INTERFACE 


A0-A15 


S 
. 


VL82C37A is enabled (bit 2 in the 
command register is 0) and that 
channel is unmasked, a DMA service 
will occur after one byte of the Address 
Register has been reprogrammed. This 
can be avoided by disabling the 
controller - setting bit 2 in the command 
register - or masking the channel before 


When the processor replies with a HLDA 
signal, the VL82C37A takes control of 
the address. data, and control buses. 
The address for the first transfer 
operation is output in two bytes - the 
least significant eight bits on the eight 
address outputs, and the most signifi- 
cant eight bits on the data bus. The 
contents of the data bus are then 


ADDRESS BUS A0-A15 
n 
>. 


O 


VL82C37A 


programming another registers. Once 
the programming is complete, the 
controller can be enabled (unmasked). 


After power-up all Internal locations, 
including the Mode registers, should be 
loaded with a valid value. This should 
be done to unused channels as well. 


latchediinto the 8282 8-bit latch to 
complete the full 16 bits of the address 
bus. The 8282 is a high-speed, 8-bit, 
three-state latch in a 20-pin DIP 
package. After the initial transfer takes 
place, the latch is updated only after a 
carry or borrow is generated in the least 
significant address byte. Four DMA 
channels are available when one 
VL82C37A DMA Controller is used. 


A8-A1 5 
6 —O E 
8282 


8-BIT LATCH 
STB 


BUSEN 
AEN 
A0-A3 
A4-A7 
—CS 
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VL82C37A 
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RESET-MEMW 
-IOW 
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I 
CLK 
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-IOR 


O 
O 
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FIGURE 2. COMMAND REGISTER 
7654321 04--5" 
IIIIIIIIIIIIIIIIIJ 
““'“"°' 
@ 
0 
Memory-to-memory disable 
1 
Memory-to-memory enable 


0 
Channel 0 address hold disable 


1 
Channel 0 address hold enable 
X 
If bit 0 = 0 


0 
Controller enable 
1 
Controller disable 


0 
Normal timing 
1 
Compressed timing 
X 
If bit 0 = 1 


0 
Fixed priority 
1 
Rotating priority 


0 
Late write selection 
1 
Extended write selection 
X 
If bit 3 = 1 
' 


0 
DREQ sense active high 
1 
DREQ sense active low 


0 
DACK sense active low 
1 
DACK sense active high 


FIGURE 3. MODE REGISTER 


765432104—iBif 
IIIIIIIICIIIIIII 
"""“"" 


00 
Channel 0 Select 
01 
Channel 1 Select 
10 
Channel 2 Select 
11 
Channel 3 Select 


00 
Verify transfer 
01 
Write transfer 
10 
Read transfer 
11 
Illegal 
XX lfbits6and7= 11 


0 
Autoinitialization disable 
1 
Autoinitialization enable 


0 
Address increment select 


1 
Address decrement select 


00 
Demand mode select 
01 
Single mode select 
10 
Block mode select 
11 
Cascade mode select 
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FIGURE 4. REQUEST REGISTER 
FIGURE 6. MASK REGISTER (SELECT MODE) 


765432104——:{:b°r 
1ss4a21o<-—- 


Don't 
care 
I11111111 
m 
1 
O0 


FIGURE 5. STATUS REGISTER 


765432104-— 
I11111111 
""""’°' 
IE 


-L-&—L—L 


l:I:1:1:l:i:|:i:| 
,0 


I 
I 
01 
DON'T 
1 0 
°a'° 
11 


Select channel 0 
Select channel 1 
Select channel 2 
Select channel 3 


O1 
10 
11 
0 
0 
Reset request bit 
1 
1 
Set request bit 


Bit 
Number 


Select channel 0 mask bit 
Select channel 1 mask bit 
Select channel 2 mask bit 
Select channel 3 mask bit 


Clear mask bit 
Set mask bit 


FIGURE 7. MASK REGISTER (MASK MODE) 


B“ 
1ss4a21o<——- 
I11111111 


Channel 0 has reached TC 
I 
1. 
0 
Channel 1 has reached TC 
00'" 
1 
Channel 2 has reached TC 
°a'° 
Channel 3 has reached TC 
I‘) 


Channel 0 request 
Channel 1 request 
0 
Channel 2 request 
I 
Channel 3 request 
0 
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TABLE 2. REGISTER CODES 


Signals 


Reglster 
Operation 
-CS 
—IOR -IOW 
A3 
A2 
A1 


0 
1 
0 
1 
0 
0 
Command 
Write 


Mode 
Write 


Request 
Write 


Mask 
Set/Reset 


Mask 
Write 


Temporary 
Read 


Status 
Read 


A0 


O 


0 
1 
O 
1 
0 
1 
1 


O 
1 
0 
1 
0 
0 
1 


O 
1 
0 
1 
O 
1 
O 


O 
1 
O 
1 
1 
1 
1 


0 
0 
1 
1 
1 
O 
1 


0 
0 
1 
1 
0 
O 
0 
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Bit 
Number 


Clear channel 0 mask bit 
Set channel 0 mask bit 


Clear channel 1 mask bit 
Set channel 1 mask bit 


Clear channel 2 mask bit 
Set channel 2 mask bit 


Clear channel 3 mask bit 
Set channel 3 mask bit 
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TABLE 3. SOFTWARE COMMAND CODES 


A3 



Signals 


-IOW 


FIGURE 8. CASCADED VL82C37A CONTROLLERS 


MICROPROCESSOR 
IST LEVEL 



I 
HRO 
DREQ 


HLDA 
DACK 


VL82C37A 


DACK 


INITIAL DEVICE 


Operation 


Read Status Register 


Write Command Reglster 


Illegal 


Write Request Register 


Illegal 


Write Single Mask Register Bit 


Illegal 


Write Mode Register 


Illegal 


Clear Byte Pointer Flip/Flop 


Read Temporary Register 


Master Clear 


Illegal 


Clear Mask Reglster 


Illegal 


Write All Mask Register Bits 


2ND LEVEL 


VL82C37A 


HRQ 


HLDA 


VL82C37A 


ADDITIONAL DEVICES 
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TABLE 4. WORD COUNT AND ADDRESS REGISTER COMMAND CODES 


. 
Signals 
lntemal 
Data Bus 
c,,,,,,,,. 
,,, ,,,, 
o,,,,,,,,,,,I 
_ 


0 
1 
0 
0 
0 
0 
0 
0 
A0 A7 
0 
1 
0 
0 
0 
0 
0 
1 
- 
0 
Base and Current Address 
Write 
- 
A8 A15 


Current Address 
Read 
0 
0 
1 
0 
0 
0 
0 
0 
A0-A7 
0 
0 
1 
0 
0 
0 
0 
1 
A8-A1 5 


Base and Current Word Count 
Write 
0 
1 
0 
0 
0 
0 
1 
0 
W0-W7 
0 
1 
0 
0 
0 
0 
1 
1 
W8-W15 


Current Word Count 
Read 
0 
0 
1 
0 
0 
0 
1 
0 
W0-W7 
0 
O 
1 
0 
0 
0 
1 
1 
W8-W15 


1 
Base and Current Address 
Write 
0 
1 
0 
0 
0 
1 
0 
0 
A0-A7 
0 
1 
0 
0 
0 
1 
O 
1 
A8-A1 5 


Current Address 
Read 
0 
0 
1 
0 
0 
1 
0 
0 
A0-A7 
0 
0 
1 
0 
0 
1 
0 
1 
A8-A1 5 


Base and Current Word Count 
Write 
0 
1 
0 
0 
0 
1 
1 
0 
W0-W7 
0 
1 
0 
0 
0 
1 
1 
1 
W8-W1 5 


Current Word Count 
Read 
0 
0 
1 
0 
0 
1 
1 
0 
W0-W7 
0 
0 
1 
0 
0 
1 
1 
1 
W8-W1 5 


2 
Base and Current Address 
Write 
0 
1 
0 
0 
1 
0 
O 
0 
A0-A7 
0 
1 
0 
O 
1 
0 
0 
1 
A8-A15 


Current Address 
Read 
0 
0 
1 
0 
1 
0 
0 
0 
A0-A7 
0 
0 
1 
O 
1 
0 
0 
1 
A8-A15 


Base and Current Word Count 
Write 
0 
1 
0 
0 
1 
0 
1 
0 
W0-W7 
0 
1 
0 
0 
1 
0 
1 
1 
W8-W1 5 


Current Word Count 
Read 
0 
0 
1 
O 
1 
0 
1 
0 
W0-W7 
0 
0 
1 
0 
1 
0 
1 
1 
W8-W15 


3 
Base and Current Address 
Write 
0 
1 
O 
O 
1 
1 
0 
0 
A0-A7 
0 
1 
0 
0 
1 
1 
0 
1 
A8-A1 5 


Current Address 
Read 
0 
0 
1 
0 
1 
1 
0 
0 
A0-A7 
0 
0 
1 
0 
1 
1 
0 
1 
A8-A1 5 


Base and Current Word Count 
Write 
0 
1 
0 
0 
1 
1 
1 
0 
W0-W7 
0 
1 
0 
0 
1 
1 
1 
1 
W8-W15 


Current Word Count 
Read 
0 
0 
1 
O 
1 
1 
1 
0 
W0-W7 
0 
0 
1 
O 
1 
1 
1 
1 
W8-W15 
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TABLE 5. DMA MODE AC CHARACTERISTICS 
VL82C37A 


VL82C37A 04 
VL82C37A 05 
VL82C37A 


NU1 


-L 
|\)'ODO 


-A OI <»a 
TAEL 
AEN High from CLK Low (S1) Delay 'l'ime 


TAET 
AEN Low from CLK High (S1) Delay TIITI9 


TAFAB 
ADR Active to Float Delay from CLK High 


TAFC 
Read or Write Float from CLK High 


TAFDB 
DB Active Float Delay from CLK High 


TAHR 
ADR from Read High Hold "lime 


TAHS 
DB from ADSTB Low Hold 'I'ime 


TAHW 


-L-Lb OOO OO 


00 


-A-L—L1.0N 
(DIO OOOO 


-co OOO 


0| 


-L—L_L_L-5-L\l\I\I\I 
\lI\)OOOO 
OO 


-I—I 
|0 


-4-\]O 
(A01 U1U1 


TCY 100 
TCY 100 
CY 75 


CY 50 
—I 
ADR from Write High Hold Time 
TOY 50 
CY 50 


DACK Valid from CLK Low Delay 'l'ime (Note 7) 
2 


TAK 
—EOP High from CLK High Delay 'l'ime (Note 10) 


-EOP Low from CLK High Delay TIt116 


TASM 
ADR Stable from CLK High 


TASS 
DB to ADSTB Low Setup Time 


TCH 
Clock High Time (Transitions 5 10 ns) 


TCL 
Clock Low Time (Transitions 510 ns) 


TCY 
CLK Cycle 'l'ime 


TDCL 
CLK High to Read or Write Low Delay (Note 4) 


TDCTFI 
Read High from CLK High (S4) Delay Time (Note 4 


TDC 
Write High from CLK High (S4) Delay (Note 4) 


TDQ1 
HRQ Valid from CLK High Delay Time (Note 5) 
TDQ2 


-EOP Low from CLK Low Setup Time 


|\)-L(,1-L 


-L-L 
-A U1 
(O 
I'D OO 


\lOO 


-zsOJQ U1 


-\l\l 
- O 
U1 
I'DOO 


O 
2 
5 


TEPS 


TEPW 
—EOP PUIS9 Width 


TFAAB 
ADR Float to Active Delay from CLK High 


TFAC 
Read or Write Active from CLK High 


TFADB 
DB Float to Active Delay from CLK High 


THS 
HLDA Valid to CLK High Setup 'l'ime 


TIDH 
Input Data from -MEMR High Hold 1'ime 


TIDS 
Input Data to -MEMR High Setup Time 


TQDH 
Output Data from —MEMW High Hold Time 


TODV 
Output Data Valid to —MEMW High 


TQS 
DREQ to CLK Low (S1 S4) Setup Time 


TRH 
CLK to READY Low Hold Time 


TRS 
READY to CLK Low Setup Time 


TSTL 
ADSTB High from CLK High Delay Time 


TSTT 
ADSTB Low from CLK High Delay 1"ime 


-\lNI 
U1 U1 


-A-A -oiOO 


-A-L-L\]l\)O\I 
0'1 U1O 


-A(.0O 


-—-zsO 
U1 


_;, 
-L 
.-; 
-L Q 
O 


Explanatory notes follow DC Characteristics Table. 
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Unit 
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FIGURE 9. DMA TRANSFER TIMING (SEE TABLE 5.) 
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FIGURE 10. MEMORY-TO-MEMORY TRANSFER TIMING (SEE TABLE 5) 
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TABLE 6. PERIPHERAL MODE AC CHARACTERISTICS 
VL82C37A 


VL82C37A 
VL82C37A 05 
VL82C37A 08 


Symbol 
Parameter 


TAFI 
ADR Valid or —CS Low to Read Low 


TAW 
ADR Valid to Write High Setup Time 


TCW 
CS Low to Write High Setup Time 


TDW 
Data Valid to Write High Setup ‘Time 


TFIA 
ADR or CS Hold from Read High 


TFIDE 
Data Access from Read Low (Note 3) 


TRDF 
DB Float Delay from Read High 


TRSTD 
Power Supply High to RESET Low Setup Time 


TFI$T$ 
RESET to First -IOW 


TRSTW 
RESET Pulse Width 


TRW 
Read Vldth 


TWA 
ADR from Write High Hold Time 


TWC 
CS High from Write High Hold Time 


TWD 
Data from Write High Hold Time 


TWWS 
Wnte Width 


Q) 
_&._&.C) 
(DO)C 
CC 


Q 
_L 


C 


C 


2TCY 
2TCY 
2TCY 


Explanatory notes follow DC Characteristics Table. 


FIGURE 1 1. SLAVE MODE WRITE TIMING (SEE TABLE 6) 
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FIGURE 12. SLAVE MODE READ TIMING (SEE TABLE 6) 
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FIGURE 1 3. READY TIMING (SEE TABLE 5) 
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FIGURE 1 4. COMPRESSED TRANSFER TIMING (SEE TABLE 5) 
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ABSOLUTE MAXIMUM RATINGS 
Supply Voltage 
-0.5 to 7.0 V 
Input Voltage 
-0.5 to 5.5 V 
Output Voltage 
-0.5 to 5.5 V 
Operating Temperature 
0 °C to +150°C 
Storage Temperature -65°C to +150°C 


Stresses above those listed under 
"Absolute Maximum Ratings" may cause 
permanent damage to the device. This 
is a stress rating only and functional 
operation of the device at these or any 
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other conditions above those indicated 
in the operational sections of this 
specification is not implied. Exposure to 
absolute maximum rating conditions for 
extended periods may affect device 
reliability. 


DC CHARACTERISTICS: 


Symbol 


VOH 


VOL 


VIH 


VIL 


ILI 


ILO 


ICC 


C0 


C1 


C10 


Parameter 
Typ (1) 


:5 
!\> U1# 


-s:>- @ 
u-l 
u-lm 
(,1 
1Lc-I 
'0'0-0 
.1: 
< 


V 
Output High Voltage 


V 
Output Low Voltage 


Input High Voltage 
VCC + O5 
V 


lnput Low Voltage 


lnput Load Current 
i 


Output Leakage Current 
5; 


VCC Supply Current 


Output Capacitance 


Input Capacitance 


I/O Capacitance 


AC and DC Characteristics Notes: 


1. Typical values are for TA -= 25°C, nominal supply voltage, and nominal processing parameters. 


Test Condltlons 


IOH .. -200 |.iA 


IOH =- -100 p.A (HRO Only) 


IOL =- 2.0 mA (data bus) —EOP 
IOL = 3.2 mA (other outputs) (8) 
IOL = 2.5 mA (ADSTB) (8) 


O V 5 VIN s VCC 


0.45 V 5 VOUT 5 VCC 


Clk. Freq. =- 5 MHz, 8MHz 


fC = 1.0 MHz, Inputs = 0 V 


2. Input timing parameters assume transition times of 20 ns or less. Waveform measurement points for both input and 
output signals are 2.0 V for high and 0.8 V for low, unless otherwise noted. 


3. Output loading is 1 TTL gate plus 150 pF capacitance, unless otherwise noted. 


4. The net -IOW or —MEMW pulse width for normal write will be TCY-100 ns and for extended write will be 
2TCY-100 ns. The net -IOR or-MEMR pulse width for normal read will be 2TCY-50 ns and for compressed read 
will be TCY-50 ns. 


5. TDQ is specied for two difierent output high levels: TDQ1 is measured at 2.0 V, TDQ2 is measured at 3.3 V. The 
value for TDQ2 assumes an external 3.3 Kohm pull-up resistor connected from HRQ to VCC. 


6. DREQ should be held active until DACK is returned. 


7. DREQ and DACK signals may be active high or active low. Timing diagrams assume the active high mode. 


8. Successive read and/or write operations, by the external processor, to program or examine the controller must be 
timed to allow at least 400 ns forthe VL82C37A-05 and at least 250 ns forthe VL82C37A-08, as reoovery time between 
active read or write pulses. 


9. -EOP is an open-collector output. This parameter assumes the presence of a 2.2 kQ pull-up resistor to VCC. 


10. Pin 5 is an input that should always be at a logic high level. An internal pull-up resistor will establish a logic high 
when the pin is left floating. lt is recommended, however, that pin 5 be tied to VCC. 
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FEATURES 


- Full-function, single-chip interface to 
Parallel System Bus ( iPSB ) 


- Implements full message-passing 
protocol on iPSB bus 


- Offloads managing iPSB bus 
arbitration, transfer and exception 
cycles from local CPU 
' 


- Maximizes performance on iPSB bus 
and local on-board bus 


~ Simplifies highly functional 
interconnect space implementations 
for both local and iPSB buses 


- Processor-independent interface to 
iPSB bus 


~ Supports co-existence of dual-port 
and message-passing architectures 


® VLSI TECHNOLOGY, mc. 
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MESSAG E-PASSING COPROCESSOR 


DESCRIPTION 
The VL82C389 Message-Passing 
Coprocessor (MPC) provides a high- 
integration interface solution for the 
Parallel System Bus (iPSB) of the 
Multibus II architecture. The device 
integrates the logic necessary to 
implement a full bus interface solution, 
including support for message passing 
and interconnect spaces, as well as 
memory and I/O references on the iPSB 
bus. In addition, the MPC is designed to 
simplify implementation of dual-port 
memory functions for those designs 
that must co-exist with message 
passing. 


The message address space in the 
Multibus II architecture has been 
defined to provide a high-performance 
interprocessor communication mecha- 
nism for multiprocessor systems. By 
performing the message space inter- 
face, the VL82C389 MPC offloads the 
interprocessor communication tasks 
from the local on-board CPU, which 
decouples the local bus activities from 


MULTlBUS® II 


the iPSB bus activities. Decoupling 
these two functions eliminates an 
interface bottleneck present in traditional 
dual-port architectures. The bottleneck 
is a result of having a dual-port architec- 
ture that requires a tight coupling 
between a processor and some shared 
memory resource of limited size. 
Unfortunately, as the number of 
processors increases, the dual-port 
structure degrades system performance 
even more dramatically. 


Using the MPC component to decouple 
these resources yields several enhance- 
ments to system performance. For 
example, resources on the local 
processor bus and Parallel System Bus 
are not held in wait states while arbitra- 
tion for other resources is performed. In 
addition, each transfer can occur at the 
full bandwidth of the associated bus. 
The benefit of this is the increased 
overall system performance that results 
from processors being able to process 
other tasks in parallel, with message 
transfers being handled by the MPC 
component. 


BLOCK DIAGRAM 
I 
LOCAL BUS INTERFACE 


LOCAL BUS 
MULTIPLEXING 
BUFFERS AND 
CONTROL 


INTERNAL LOCAL eus 


INTERCONNECT 
MEMORY. vo AND 
MESSAGE 
Q 
REGISTERS mo 
INTERCONNECT 
BUFFERS AND 
OPERATION 
REFERENCE 
CONTROL 
INTERCQNNEQT 
CONTROL 
CONTROL 
eus SPACE 
INTERFACE 
I 
DUAL.pQ|qT 


INTERNAL IPSB BUS 
MEMORY 
' — T“ 
' 
'_ 
I 
CONTROL 
INTERFACE 
ARBITRATION 
*RA~SFERA~=> 
582% O 
EXCEPTION 
CONTROL 
CONTROL 


iPSB BUS INTERFACE 
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ORDER INFORMATION 


Part 
Number 
Package 


VL82C389-GC 
Ceramic Pin 
Grid Array 
(PGA) 


Note: Operating temperature range is 
0°C to +70°C 
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PIN DIAGRAM 
CERAMIC PIN GRID ARRAY (PGA) 
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1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 


D0 
D2 
D4 
D7 
D9 
D12 
D14 
D17 
D20 
D23 
D26 
D28 
D30 
D31 
IAD7 
A 
@145 @145 @143 @141 @135 @134 @133 @129 @125 @125 @121 @120 @115 @115 '@111 


A5 
01 
03 
05 
05 
011 
013 
015 
019 
022 
025 
027 
029 
lAD5 
lAD6 


B 
@4 
@147 @144 @142 @139 @135 @135 @125 @124 @122 @119 @115 @114 @110 @107 


-BE3 
A4 
vss 
05 
vss 
D10 
vcc 
015 
015 
021 
024 
vss 
IAD3 
IAD4 
—lWR 
c 
@7 
@3 
@149 @145 @140 @137 @131 @130 @127 @123 @117 @113 @109 @105 @103 


—8E2 
A3 
A2 
vcc 
vss 
vcc 
IAD1 
lAD2 
-mo 
0 
@9 
@5 
@2 
@1 
@132 
@112 @105 @104 @102 


-REGSEL -BE1 
-BEO 


E 
@12 @e 
@5 


IDREO —MEMSEL —lOSEL 


F 
@15 
@11 
@10 


ODREO -IDACK-ODACK 


G 
@15 
@13 
@14 


-RD 
-WR 
-WAIT 


H 
@15 
@17 
@19 


MINT 
—I_OCK 
vss 
J 
@21 
@2s 
@20 


EINT 
-ERR -coM 


K 
@22 
@24 
@25 


TOP VIEW 


IADO 
IAST 
-IREO 
@105 @101 @100 
vss 
—BADO -BAD1 


@399 (998 
@396 
—BAD2 -BAD3 —BAD4 
@94 
@97 
@95 


—BAD5 —BAD6 —BAD7 
@93 
@91 
@92 


-BAD8 -e/109 -BAD10 
@55 
@57 
@90 
vss -BAD11-BAD12 
@e4 
@55 
@59 


-SEL -esco -esc1 
-BAD13—BAD14—BAD15 
L 
@25 
@27 
@31 
@e0 
@52 
@55 


-BSC2 -escs -esc4 
vcc 
vcc -BAD16-BAD17—BAD18 
M 
@2e 
@30 
@34 
@35 
@75 
@75 
@79 
@53 


-BSC9 SCDIRO -esc5 
vss 
-ARB5 
vss -REFADR vcc 
vss -BPARO vss —BAD27 vss —BAD19-BAD20 
N 
@29 
@32 
@35 
@39 
@43 
@47 
@51 
@55 
@57 
@52 
@55 
@71 
@74 
@77 
@a1 
-esce -esc7 -ARB1 —ARB3 —ARB4-BREO—BUSERRLACHN—BPAR3-BPAR1-BAD30—BAD28-BAD25-BAD23—BAD21 


P 
@33 
@35 
@41 
@42 
@45 
@45 
@50 
@54 
@50 
@51 
@54 
@57 
@59 
@72 
@75 
-esce SCDIR1 -ARBO -ARB2 -RSTNC ADDIR TIMOUT eecu< RESET -BPAR2-BADS1—BAD29—BAD26-BAD24-BAD22 
o 
@37 
@40 
@44 
@45 
@49 
@52 
@53 
@55 
@55 
@59 
@53 
@55 
@55 
@70 
@73 


FUNCTIONAL DESCRIPTION 
Arbltratlon,Transfer,and Exception 
Cycle ProtocolSupport 
The message-passing coprocessor 
implements the full arbitration, transfer, 
and exception cycle protocols required 
to interface to the iPSB bus. Arbitration 
is supported for both normal fairness 
mode and high priority mode. 


The MPC performs the handshake 
protocols necessary to successfully 
complete iPSB transfer operations. 


Transfer operations include access to 
memory, I/O, message and interconnect 
address spaces on the iPSB bus. 
During the transfer cycle, the device 
generates and checks parity on the 
system control (SC) lines and on the 
address/data (AD) lines. In addition, 
the MPC component recognizes agent 
errors and bus exceptions that are 
reported to the local CPU for recovery 
action. 
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INTERFACE DESCFtIP11ON 
This section describes each interface 
noted in the block diagram on the front 
page. These interfaces include the 
local bus, the iPSB bus, the 
interconnect bus, and dual-port mem- 
ory. 


The Local Bus Interface 
The local bus interface is used to 
provide a processor-independent path 
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from the on-board CPU to the IPSB bus. 
This interface supports direct references 
(memory, I/O, and interconnect address 
spaces) to the iPSB bus, references to 
local on-board interconnect space, and 
the full protocol for unsolicited and 
solicited message operations to and 
from the on-board CPU. Within the 
MPC component, local bus interface 
supportconsists of three logical 
interfaces: register, reference, and 
DMA. The register interface is used for 
message operations and access to 
interconnect address register on-board. 
These operations are completed fully 
asynchronous to the bus clock or 
interconnect bus operations. The 
reference interface is used to access 
resources asynchronous to the CPU 
(local interconnect space and memory, l/ 
O, and interconnect address spaces on 
the iPSB bus). 
The DMA interface is 
used to transfer data for solicited 
message operations. This interface is 
designed to allow either two-cycle or 
single-cycle transfers. Single-cycle 
transfers allow direct transfer of data 
between the MPC and memory. To 
achieve higher performance via single- 
cycle transfers, the DMA interface is 
optimized for aligned data structures; 
however, operation on arbitrary byte 
strings is also supported. 


IPSB Buslnterface 
The iPSB bus interface implements a full 
32-bit interface to the iPSB bus. This 
implementation includes arbitration, 
requestor control, replier control, and 
error handling functions. As a re- 
questor, the MPC component supports 
references to memory, VO, and intercon- 
nect spaces, as well as message packet 
transmission. As a replier, the MPC 
supports interconnect space and 
message packet reception. In addition, 
this interface provides significant 
management services for external dual 
port memory. These services include: 
address recognition, iPSB bus replier 
handshake, agent error checking, and 
bus parity generation and checking. 
Although this device handles the 
majority of errors, the dual-port memory 
controller is still responsible for genera- 
tion and checking of memory data parity 
(not bus parity). 


lnterconnectBusSupport 
Simply stated, the interconnect address 
space provides a physical rather than 
logical addressing mechanism for 
software initialization and configuration 
of system parameters (reduces jumper 
configuration) and system-level diagnos- 
tics. The interconnect bus provides a 
simple 8-bit path between the MPC and 
a user-defined design for the implemen- 
tation of interconnect space. All 
references to interconnect space (either 
from the local bus or the IPSB bus) are 
routed through this path for service. In 
addition, this interconnect bus can be 
used for such non-reference-related 
activities as diagnostics. An example of 
a highly functional interconnect space 
implementation by the microcontroller 
implementation of Intel's iSBC 386/100. 
Further details of this implementation 
are available in the iSBC 386/100 
Hardware Reference Manual (Intel order 
number: 146705-001). 
Dual-Port Memory Support 
Although the MULTIBUS ll architecture 
has defined the message address space 
for optimized performance of inter- 
processor communication, more 
traditional designs can use dual-port 
memory implementations. The iPSB 
bus interface has been defined to allow 
co-existence of dual-port memory and 
message-passing architectures; 
however, it should be noted that the 
IPSB bus interface is optimized for 
message-passing architectures. The 
MPC is designed to support this co- 
existence. The device can be configured 
to recognize a range of addresses in 
memory space and act as an iPSB bus 
replier when appropriate. If an address 
match is detected, the MPC signals the 
external dual-port memory controller of 
the request. While the MPC provides an 
error detection and recovery mechanism 
for most agent errors and bus excep- 
tions in a dual-port design, it is still the 
responsibility of the dual-port memory 
controller to generate and check 
memory data parity. 


Slngle-Board ComputerConguration 
The message passing coprocessor 
component provides a processor- 
independent iPSB bus interface solution 
for intelligent SBC boards. Examples 
include CPU boards, intelligent periph- 
eral controllers, file servers, intelligent 
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data communications controllers, and 
graphicsmage processors. This 
component is optimized for bus master 
or intelligent slave designs. Using the 
MPC reduces overall board real estate 
required for the iPSB bus interface. The 
MPC improves system reliability by 
performing the error checking and 
reporting protocols defined in the IPSB 
bus interface specification. 


Message Support 
The MPC provides full support for 
unsolicited and solicited messages. For 
solicited messages, the MPC supports a 
one-message-deep transmit FIFO and a 
four-message-deep receive FIFO. For 
solicited messages, the MPC supports 
one output channel and one input 
channel. Each channel has two packet 
buffers to allow pipelined operations on 
the local and IPSB buses. These 
features provide the required level of 
support necessary to implement the 
high-bandwidth message-passing facility 
defined in the Multibus II architecture. 


Unsolicited Message Support 
Unsolicited message support in the 
MPC is provided on the local bus via a 
register interface and on the IPSB bus 
with a packet transfer mechanism. An 
unsolicited message is initiated by the 
sending host CPU transferring a 
message to its local MPC. The transfer 
is performed as a series of register 
operations to the transmit FIFO. An un- 
solicited message may be from 4 to 32 
bytes in length in four-byte increments. 


Once the unsolicited message is 
transferred to the MPC, the sending 
host is free to discard the message in 
memory and process another task if it so 
chooses. In parallel, the MPC requests 
access to the iPSB bus for the pending 
transfer. Once the iPSB bus is obtained, 
the sending MPC transfers the mes- 
sage, as a single packet, to the receiv- 
ing agent. 


The receiving agent recognizes the 
incoming packet by its destination 
address field. If the MPC on the 
receiving agent detects a match 
between its message host ID and the 
destination address field, the packet is 
stored in a buffer and checks for error 
conditions. Any errors found are 
signaled to the sending MPC via the 
iPSB bus protocol. 
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Assuming the packet received is error- 
free, the receiving host CPU is informed 
of the message via an interrupt signal 
generated by the MPC. The host 
responds to this interrupt by performing 
a series of register operations to 
retrieve the message from the receive 
FIFO. 


If an error occurs during the transfer of 
an unsolicited message over the IPSB 
bus, the sending MPC takes recovery 
action. If the error is a NACK, the MPC 
retries the message a predetermined 
number of times. All other errors are 
reported back to the sending host CPU 
for recovery actions. The host CPU is 
signaled via an interrupt and can 
retrieve the unsolicited message, with 
error status, through the error FIFO. 
Again, this operation is performed with 
a series of register operations. 
Sollclted Message Support 
Sollclted message transfers can be 
divided into three basic phases: nego- 
tiation, data transfer, and completion. 
The negotiation phase of the solicited 
transfer requires the exchange of two 
special unsolicited messages between 
the sending and receiving agents. The 
buffer request message is transferred 
from the sending agent to the receiving 
agent and the buffer grant is returned 
from the receiving agent to the sending 
agent. The MPC supports the transfer 
of these messages with the standard 
transfer protocol on the iPSB bus as 
previously described for the typical 
unsolicited message. 


A solicited message transfer is initiated 
by the sending host CPU writing a 
buffer request message to the sending 
MPC transmit FIFO. The sending MPC 
recognizes the message as a buffer 
request and saves the following infor- 
mation. The destination and source 
addresses are saved for use in the data 
transfer phase. The request ID is saved 
for identification during completion or 
cancel operations. The transfer length is 
saved to determine the end of transfer 
and may contain any number of bytes. 


The MPC pads the transfer to an even 
four-byte increment on the iPSB bus. 


The sending MPC then assigns a 
sender liaison ID and transfers the 
buffer request message packet on the 
iPSB bus. The sender liaison ID is used 
to bind the buffer grant ( or reject ) to its 
corresponding buffer request when it is 
received back at the sending MPC. This 
allows the protocol to be extended to 
multiple concurrent transfers in the 
future. 
' 


The transfer phase is handled by the 
sending and receiving MPCs and their 
DMA controllers. Neither host CPU is 
involved in the transfer, and each may 
be processing other tasks during the 
transfer. At the sending agent, the 
transfer phase slightly overlaps the 
negotiation phase. As soon as the 
buffer request packet is sent error-free 
on the iPSB bus, the sending MPC pre- 
fetches up to two packets of data and 
prepares for transmission. Upon 
receiving the buffer grant and storing 
the necessary parameters, the data 
packet transfer is initiated. Data packets 
are then sent on the iPSB bus using 
full-bandwidth block transfers, at 
intervals defined by the duty cycle 
parameters, until the transfer is com- 
plete. The end of transfer is signaled to 
the receiving MPC by the last data 
packet. A solicited transfer may wnsist 
of from one to 32 packets. Packets are 
bound to 32 bytes plus header, with 
total transfers limited to 16M bytes. 


At the receiving agent, the transfer 
phase begins after a buffer grant packet 
has been sent error-free on the iPSB 
bus. The receiving MPC then detects 
data packets, verifies the liaison ID, and 
stores the data. If the solicited input 
channel is not active (e.g., due to local 
cancel) or the liaison ID does not 
match, an agent error is signaled on the 
iPSB bus. Errors during the transfer 
phase are rare. Flow control using the 
duty cycle parameter prevents NACK 
problems, and the receiver has re- 
sponded with a buffer grant guarantee- 
ing its existence and ability to perform 
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the transfer. In the rare case that an 
error does occur, the MPC provides a 
retry algorithm for NACKs and reports 
exceptions or other agent errors 
immediately. The error is signaled to 
the host CPU by entering the comple- 
tion phase. Errors generate an interrupt 
and provide error status. 


The completion phase consists of a 
signal from the MPC to its correspond- 
ing host CPU. The signal consists of an 
interrupt followed by a series of register 
operations on the local bus. In all 
cases, the completion operation clears 
all states associated with the solicited 
operation in the MPC, allowing another 
operation to be initiated. 


The MPC guarantees fail-safe operation 
for all aspects of the solicited message 
transfer, assuming the bus clock 
remains active ( if the bus clock fails, all 
transfers cease, eliminating the need 
for recovery). This capability is provided 
by the error detection and reporting 
already discussed for bus-related 
problems and by two fail-safe counters 
that protect against fatal hardware or 
software errors on the sending or 
receiving agents. Recovery is provided 
to free a solicited message resource 
that would otherwise be tied up 
indefinitely, which eliminates the need 
for a fail-safe software timer. 


It is important to note that the fail-safe 
counters are not intended for normal 
flow control. If a receiving host CPU 
accumulates a significant queue of 
buffer requests from its MPC, it should 
use unsolicited messages_(and possibly 
rejects) to free channels in the system 
for other uses. The fail-safe counters 
are only intended to replace the need 
for a software timer to recover from 
otherwise fatal hardware and software 
errors. 


For a more comprehensive explanation 
of the MPC function, please refer to the 
Intel document, Multibus ll Message 
Passing Coprocessor External Product 
Specification ( Engineering Document 
Number: 149300-001). 
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SIGNAL DESCRIPTIONS 
The MPC signals can be classified into five interface groups: the IPSB bus, the dual-port RAM, the local bus, the interconnect bus 
and 
ower/ round 
This table describes the individual si nals for each ofthese interfaces 
Slgnal 
Pln 
Name 
Number 
Slgnal 
Descrlptlon 


-BREO 
48 


-ARBO - 
44, 41, 46, 42, 
-ARB5 
45, 43 


—BADO- 
63, 64, 66-73, 
—BAD31 
77-83, 85-98 


-BPARO, 
62, 61, 59, 60 
-BPAR1, 
—BPAR2, 
-BPAR3 


ADDIR 
52 


—REFADR 
51 


SCDIRO, 
32,40 
SCDIR1 


-BSCO- 
27-31, 33-37 
-BSC9_ 


The bus request is a bidirectional, open-drain signal with high current drive. It connects directly 
to the IPSB bus. As an input, it indicates that there are agents awaiting access to the bus. In fair 
access mode, this inhibits the MPC from activating its own request. As an output, this signal is 
used to request bus access. Further details can be found in the IPSB bus specification. 


The arbitration signals are bidirectional, open-drain signals with high current drive. They connect 
directly to the iPSB bus.These signals are used during normal operation to identify the mode and 
arbitration ID of an agent during arbitration cycles. During system initialization (while reset is 
active) , these signals are used to initialize slot and arbitration IDs. 
Further details are available in 
the iPSB , bus specification. 


The address/data signals are bidirectional lines that connect to the iPSB bus —AD signals through 
74F245 or equivalent transceivers. Further details are available in the iPSB bus specification. 


—BAD31 
-BAD27 
-BAD26 
-BAD25 
-BAD24 


88 El 
7‘ 
7° 
—BAD23 
-BAD19 
-BAD18 
-BAD17 
-BAD16 


78 
i 
7’ 
78 
78 
-BAD15 
-e/1011 
-BAD10 
-9/109 
—BAD8 


88 ll 
8’ 
88 
-BAD7 
-BAD3 
-BAD2 
-BAD1 
-BADO 


88 ill 
87 
88 


The byte parity signals are bidirectional lines that connect to the iPSB bus PAR signals through 
a 74F245 or equivalent transceiver. These signals are used to receive byte parity for incoming 
operations and to drive byte parity for outgoing operations. The MPC is responsible for parity 
generation and checking even if the address/data signals are driven from another source (e.g., 
dual-port memory data, address for reference). Further details are available in the iPSB bus 
specification. 


The AD direction signal is an output used to control the direction of the 74F245 or equivalent 
transceivers for the -BADO through —BAD31 and -BPARO through -BPAR3 signals. Activating this 
signal drives data to the iPSB bus. 


The reference address signal is an output from the MPC used to enable external address buffers for 
memory and I/O reference operations. Activating this signal drives the reference address onto the 
—BAD bus. 


The control/handshake direction signals are outputs used to control the direction of the 74F245 or 
equivalent transceivers for the -BSC signals. The SCDIRO signal is used for —BSCO - --BSC3 and 
—BSC9. The SCDIR1 signal is used for-BSC4 - -BSC8. Activating these signals drives data to the 
iPSB bus. 


The control/handshake signals are bidirectional lines that connect to iPSB bus -SC signals through 
74F245 or equivalent transcievers. Details on the operation of these signals are available in the 
IPSB bus specification. 


-BSC9 
-BSC8 
Ii! 
37 


537 


SIGNAL 
Slgnal 
Name 


BBCLK 


TIMOUT 


LACHN 


RESET 


—BUSERR 


-RSTNC 


-SEL 


—COM 


-ERR 


DO - D31 
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DESCRIPTIONS (c0111.) 
Pln 
Number 


55 


53 


54 


58 


50 


49 


26 


31 


24 


114-130, 133- 
139, 141-148 


Slgnal 
Descrlptlon 


The bus clock input signal is a buffered version of the iPSB bus -BCLK signal. It is assumed that a 
74AS1804A or equivalent buffer is used. This clock is used for all synchronous internal MPC timing. 


The time-out input signal is used to detect a time out condition signalled by the central services 
module (CSM). This signal is connected to the iPSB bus through a 74AS1804A or equivalent buffer 


The latch signal is an input used during initialization of slot and arbitration IDs. When the RESET 
signal is active, this signal indicates when slot and arbitration IDs are available. This signal is 
connected to the iPSB bus through a 74AS1804A or equivalent buffer. Further details on 
initialization are available in the iPSB bus specification. 


The RESET signal is an input used to put the MPC in a known state. Only the parts of the MPC 
involved with initialization of slot and arbitration IDs remain unaffected. This signal is buffered from 
the iPSB bus by a 74AS1804A or equivalent buffer connected to the -RST signal. 


The bus error signal is a bidirectional, open-drain line with high current drive. It connects directly 
to the iPSB bus. As an input, it is used to detect bus errors signalled by other agents. As an output 
it is used to signal parity errors detected on either the —AD or -SC signal lines, handshake protocol 
violations, or for extending exception recovery of a replier. 


The reset not complete signal is a bidirectional, open-drain line with high current drive. It connects 
directly to the iPSB bus. As an input, this signal inhibits the MPC from initiating iPSB bus 
operations. As an output, it is used to prevent iPSB bus operation until an agent is finished with on- 
board initialization. This signal is activated by the RESET signal going active. It is deactivated by 
the microcontroller after the RESET signal is deactivated and initialization is complete. 


The -SEL signal is activated by the MPC to indicate a dual-port access. This signal is used to 
initiate the dual-port operation and may be used to enable the dual-port data buffers onto the BAD‘ 
bus. When the MPC completes the iPSB bus handshake on the iPSB bus, or an exception is 
detected, this signal deactivates. 


The -COM signal is activated by the dual-port memory controller to indicate that it is ready to 
complete the operation. This signal is assumed to be synchronous with the bus clock. The MPC 
activates replier ready on the iPSB bus on the next bus clock. This signal may not be deactivated 
until the EOT handshake is complete on the iPSB bus. 


The —ERR signal is activated by the dual-port memory controller to signal a memory data parity 
error. It must be stable at all times when the —COM signal is active. The MPC responds to this 
signal by completing the replier handshake on the iPSB bus using a ‘data error" agent error code. 
This signal may be asynchronous with the bus clock since it is qualified by the —COM signal. 


The data bus is a bidirectional group of signals used to transfer data between the host CPU and the 
MPC. Control is provided to allow operation of this bus with 8-, 16-, or 32-bit processors. 


D24 


117 


D16 


D31 
D 


115 


D23 


126 
128 


D15 
D 4 
D 3 
2 
D 
D8 


130 
139 


D7 
D0 


141 
148 
_LQ-L 
u-L 
c-I b 
(.0-A 
IO-8 IO 
(.0 
IO(D 


(.0....O1 
-L 
Q-L (.0 
9N -Si 
O 


-L 
-L4*8 
Niu -b 
-f> 
\1 
-L-L 
Q-L 
—lIi(0 
-4 
NNO1\lQ\l-* 
_.L....L 
-A -§ 
(D-1 
-* \l 
(D 
(O 


D 7 
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SIGNAL DESCRIPTIONS (Cont.) 
Slgnal 
Name 
Pln 
Number 
Slgnal 
Descrlptlon 


A2, 
A3, 
A4, 
A5 


-BEO, 
-BE1, 
—BE2, 
-BE3 


—MEMSEL 


—IOSEL 


-REGSEL 


-LOCK 


2, 5, 3, 4 


6, 8, 9, 7 


11 


10 


12 


23 


The address inputs are used to identify MPC registers for message and interconnect space 
operations. Note that A0 and A1 are omitted to provide a consistent register address for all data- 
bus width options. These signals are qualified by commands (e.g., —RD or -WR) in the MPC and 
therefore may “glitch” outside the specified set-up and hold window. 


The byte enable input signals are used to identify the valid bytes and for data path control during 
memory and I/O reference operations. Only combinations supported by the IPSB bus specification 
are valid. 
These are summarized in the table below. Values not shown are illegal and may result 
in unpredictable results. These signals are qualified by commands (e.g., -RD or -WR) in the MPC 
and therefore may glitch outside the specified set-up and hold window. 


Operation with 32-bit local buses requires all byte enable and data signals to be used. For 16-bit 
local buses, the -BE3 and —BE2 signals are held inactive and only D15-D0 are used. For all cases 
a read operation enables all 32 data signals, even if all byte enables are inactive. For 8-bit local 
bus operations -BE3 is held active, —BE2 is held inactive, -BE1 is connected to —A0, and -BEO is 
connected to A0. This mode uses only D7-D0. 


‘P88 888 
5 
Hmwwmwmwm 
D16 
D8 
DD 
AD24 
AD16 
AD8 
ADD 
-—- 
V8 
V8 
X 
v2 
vo 


V2 


X 


V0 


X 


V2 


X 


V0 


X 


V0 
f_f_IIII_IIT_II_(_ HiliiilllrIIHIEHIIHIH"EEIHEEIEEIHPHHHHHHHHHIHHHHHHHHHHEEHHHHHHHEEEHEEEHHHEHHEHHHHHHHHHHHIHHHHHHHEHIHHHEHHEEH 


L - Electrical low state (active) 
For reference only 
H- Electrical high state (inactive) 
Vx - Valid data bus 


The memory select input signal is used to idenfity a memory reference operation to the iPSB bus. 
It is qualified by commands (e.g., -RD or -WR) in the MPC and therefore may glitch outside the 
specified set-up and hold window. 


The I/O select input signal is used to identify an I/O reference operation to iPSB bus. It is qualified 
by commands (e.g., -RD or -WR) in the MPC and therefore may "glitch" outside the specified set- 
up and hold window. 


The register select input signal is used to identify operations to internal MPC registers used to 
perform message and interconnect space operations. This signal is qualified by commands (e.g., 
-RD or -WR) in the MPC and therefore may glitch outside the specified set-up and hold window. 


The -LOCK signal is an input to the MPC that allows back-to-back operations to be performed on 
the iPSB bus or to local interconnect space. When -LOCK is asserted, any resource accessed by 
the operation (iPSB bus or local interconnect space) is locked until the --LOCK signal is deacti 
vated. 
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SIGNAL DESCRIPTIONS (Cont.) 
Slgnal 
Name 
Pin 
Number 
Slgnal 
Descrlptlon 


-RD 


-WR 


—WAIT 


MINT 


EINT 


ODREQ 


IDREQ 


—ODACK 


—IDACK 


IADO-IAD7 


—IREQ 


IAST 


-IRD 


-IWR 


18 


17 


19 


21 


22 


16 


15 


14 


13 


104-111 


100 


101 


102 


103 


The read input signal is activated to initiate a read operation. This signal must provide clean 
transitions. 


The write input signal is activated to initiate a write operation. This signal must provide clean 
transitions. 


The -WAIT signal is driven by the MPC to hold up a transfer operation. This signal is used by the 
MPC for all accesses that require synchronization to another resource. When used, it is activated 
by a command going active and deactivated when the accessed resource is ready to complete the 
requested operation. 


The message interrupt output signal is used for all message-related signalling to the host CPU. 
This includes arrival of an unsolicited message, completion of a solicited transfer, and an error on 
message transfer. 


The error interrupt output signal is used to signal all errors related to memory, I/O or interconnect 
space operations. Internal registers in the MPC provide exact details of the error via interconnect 
space. (Even though this is a local bus signal, it will be discussed with the interconnect bus signals 
for simplicity in future sections.) 


The output channel DMA request signal is generated by the MPC to enable DMA transfer of'data 
to the MPC (e.g., output to the iPSB bus). 


The input channel DMA request signal is generated by the MPC to enable DMA transfer of data 
from the MPC (e.g., input from the iPSB bus). 


The output channel DMA acknowledge input signal is activated to perform a DMA data transferto 
theMPC. It is qualified by commands (e.g., -RD or -WR) in the MPC and therefore may glitch 
outside the specified set up and hold window. 


The input channel DMA acknowledge input signal is activated to perform a DMA data transfer from 
the MPC. It is qualified by commands (e.g., -RD or -WR) in the MPC and therefore may glitch 
outside the specified set-up and hold window. 


The interconnect address/data bus is a multiplexed bus designed to directly interface to a 
microcontroller. In addition to the MPC, other interconnect registers can be connected to this bus. 


The interconnect request signal is generated by the MPC when an interconnect operation has been 
requested either from the local bus or from the iPSB bus. This signal remains active until the 
microcontroller performs arbitration. 


The interconnect address strobe signal is an input to the MPC used to indicate that a valid address 
is on the interconnect bus.This signal may be directly connected to the ALE output of most 
microcontrollers. This signal must provide clean transitions. 


The interconnect bus read signal is an input to the MPC. This signal is used to perform a read 
operation to one of the MPC interconnect interface registers. This signal must provide clean 
transitions. When this signal is activated in conjunction with the -IWR signal, all MPC outputs are 
disabled. 


The interconnect bus write signal is an input to the MPC. This signal is used to perform a write 
operation to one of the MPC interconnect interface registers. This signal must provide clean 
transitions. When this signal is activated in conjunction with the -IRD signal, all MPC outputs are 
disabled. 
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TIMING CHARACTERISTICS TA = 08015 +7080, vcc = s v 258/. 


LOCAL BUS 


Symbol 
Parameter 
Test Condltlons 


T1 
Address and —BE Set Up To CommandActive 


Select and DACK Set Up To CommandActive 


T2 
Address —BEn —Select, and -DACK Hold 
From Command Active 


T8 
<=°mm8"8'~88~8 
K13 
T4 
Command Inactive To Read Data Disable 
(Note 1) 


T5 
Read Data Hold From Command Inactive 


.II' 
... 
Q 


OI 


‘ 


C 


1‘C @ 


I\) 


T6 
Read Data Enable From Command Active 


T7 
—WAIT Active From Command Active 
CL = 50 pF 


T8 
Command Inactive From -WAlTlnactive 


T9 
-WAIT Inactive To Read Data Valid 
CL =- 150 pF 


T10 
Command Active To Write Data Valid 


T11 
Write Data Hold From —WAlTlnactive 


T12 
Command Active To —LOCK Active (Note 2) 


T13 
LOCK Hold From —WAIT Inactive (Note 3) 


T14 
Command Active 


T15 
Read Data Valid From Command Active 
CL = 150 PF 


T16 
Write Data Set Up To 
Registers 
Command Inactive 
MA 


T17 
Write Data Hold From Command Inactive 


T18 
Command Active To MINT Or -DREO 
70 
CL = 50 pp 
Inactive Notes 
5 
( 
4 
I 


T19 
Command Active To -DREO Inactive 
Note 5 
CL = 5° PF 
( 
) 


FIGURE 1. OUTPUT WAVEFORM TEST POINTS 
FIGURE 3- A9 TEST LOAD PIRPUIT 


2.0 v 
2.0 v 


0.9 v 
0.0 v 
DEVICE 
UNDER 
FIGURE 2. INPUT WAVEFORM TEST POINTS (Note 6) 
TEST 
CL 


2.4 V 
2.0 V 
2.0 V 
T 
1.4 V 
0.8 V 
__ 
0.4 V 
0.8 V 


Notes: 
1. Disable condition occurs when the output current becomes less than the input leakage specification. 
2. Required to guarantee locking of resource. 
3. Required to guarantee resource remains locked. 
4. MINT deassertion only if no other sources are pending. 
5. For -DREO inactive timing, T19 applies to a normal last transfer de-assert condition and T18 to an error de-assert condition. 
6. 1.4 V level for BBCLK only. 
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TIMING DIAGRAMS 


LOCAL BUS REFERENCE 


-BE3 - -BEO 
—MEMSEL, 
-IOSEL, 
—REGSEL, 
A5 - A2 


-RD OR —WR 


—WAIT 


D31 - D0 


4-72 
4- T3 


Q 
(OUTPUTS OF MPC) 


031 - 00 
(INPUTS TO 
MPC) 


-LOCK 


LOCAL BUS REGISTER AND DMA OPERATIONS 


-BE3 - —BEO 
—REGSEL, 
A5_- A2, 
—|DACK, —ODACK 


-RD OR —WR 


D31 - D0 
(OUTPUTS OF MPC) 


031 - 00 
(INPUTS TO 
MPC) 


MINT, 
IDREQ, ODREQ 


V 


<—T3 


VALID 
I 
Q 


VALID 
_L 
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AC CHARACTERISTICS TA = 08010 +7080, vcc = 5 v 158/. 
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INTERCONNECT BUS 


Symbol 


T31 


T32 


T33 


T33A 


T34 


T35 


T36 


T37 


T38 


T39 


T40 


T41 


T42 


Parameter 


IAST Active 


5' 


Command Active 


Command Inactive To IAST Active 


-0 


_‘ 
-L 


(.0 


O 
N 


IAST Inactive To Command Active 


Address Set Up To IAST Inactive 


Address Hold From IAST Inactive 


Write Data Set Up To Command Inactive 


Write Data Hold From Command Inactive 


Read Data Enable From Commant Active 


Read Data Valid From Commanc Active 


Read Data Hold From Commanc Inactive 


Read Data Disable From Commant Inactive 
(Note 1) 


EINT -IREO Inactive From Command Active 
( Note 2 ) 


TIMING DIAGRAM 


IAST 


T31 


T33A 


—lRD OR -IWR 


IAD7 - IADO 
( INPUTS TO 
MP0 ) 


IAD7 - IADO 
( OUTPUTS 
FROM MPC) 


EINT 


-IREQ 


T34 
<—— T35 


ADDRESS VALI 


A 
G 
I0 


DATA VALID 


DATA VALID 


T38 


T42 


T42 


Test Condltlons 


CL =150 pF 


CL =1 50 pF 


T32 
T33 


T41 


T37 


Notes: 
1. Disable cxandition occurs when the output current becomes less than the input leakage specification. 
2. EINT inactive only on write to error register. -IREO inactive only on write to arbitration register. 
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IPSB BUS 
Symbol 


TCP 


TCL 


TCH 


TBCL 


TBCH 


TRB 


TFB 


TR 


TF 


TSK 


TCD 


TH 


Notes: 
1. 
These clock timings refer the MPC specification to the IPSB bus specifications. They assume a 74AS1804 type buffer is used 
The 500 pF load is a distributed value as defined in the iPSB bus specification. The open-drain signals are designed such that 
the output delay and bus loss meets the iPSB specification requirement. An appropriate test condition that correlates to the 


Parameter 


Clock Period 


-BCLK Low Time 


-BCLK High Time 


BBCLK Low Time 


BBCLK High Time 


-BCLK Rise Time 


-BCLK Fall Time 


BBCLK Rise Time 


BBCLK Fall T'ime 


-BCLK To BBCLK Skew ( Note 1 ) 


-BREO —BUSERR 
-RSTNC ( Note 2) 


-ARB5 - —ARBO (Note 2 3) 
-es07-~esc0 
-BAD31--BADO 


-BPAR3 - -BPARO 
Q|Q¢k To 
-BSC9 -BSC8 
Output Delay 
SCDIRO 
HI 


SCDIR1 


<5 
' 1- 


\I 


gh To Low 


Low To High 


High To Low 


Low To High 
ADDIR 


—REFADR 


-SEL 


—BREQ —BUSERR -RSTNC 


—ARB5 - -ARBO ( N019 3 ) 


—BAD31 - -BADO 
-BPAR3 
-BPARO 


-BSC9 - --BSCO 


SCDIRO SCDIR1 


ADDIR 


—REFADR 


-SEL 


:8‘o 


Hold 'lTme 
From Clock 


distributed load will be determined during characterization. 
3. 
The -ARB5 - -ARBO signal timings are with respect to the first and last clock of the arbitration period. Details are in the 
iPSB bus specification. Also, the arbitration logic has been designed to meet the loop delay specification accounting for the 
full path of input to output plus bus loss. An appropriate test condition will be determined during device characterization 
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TIMING CHARACTERISTICS TA = 08010 +7080 vcc = 5 v 25% 


Test Condltlons 


CL = 500 pF 


CL = 500 pF 


CL=75 pF 


CL=50pF 


CL=25pF 


CL=25pF 


CL=50pF 
CL=50pF 


CL=75pF 


CL=50pF 


VLSI TECHNOLOGY, INC. 


' 
VL82C389 


TIMING CHARACTERISTICS TA = 08010 +7080, vcc = 5 v 25% 


IPSB BUS(C0nt.) 


Symbol 
Parameter 
Test Conditions 


—BREO —BUSERR -RSTNC 


Turn On Delay 
—ARB5 - —ARBO (NOI81) 
F'°'“ °'°°K 
—BAD31 - -BADO 
I N°l8 4) 
-BPAR3 - -BPARO 


-BSC9 - —BSCO 


—BREQ —BUSERR -RSTNC 


Turn Off Delay 
—ARB5 - —ARBO (N019 3) 
F’°'“ °'°°k 
—BAD31 - -BADO 
l N°l8 5 I 
-BPAR3 - -BPARO 


TON 


TOFF 


-BSC9 - —BSCO 


-BREQ —BUSERR -RSTNC 


-—AR B5 - —ARBO (Note 3) 
Input Sewp 
—BAD31 - -BADO 
TSU 
To Clock 
-BPAR3 - -BPARO 
-asc9--esco 


TIMOUT LACHN RESET 


—COM -ERR 
-aaso -eusean -RSTNC 
-ARB5 - —ARe0 (Note 3) 


TIH 
Input Hold 
—BAD31 ' '"B'°~°° 
mm Clock 
-BPAR3 -BPARO 


-BSC9-—BSCO 


TIMOUT LACHN RESET 


—COM —ERR 


TIMING DIAGRAM 
IPSBBUS 


TCP -iii} 


TCH 
TFB 
4- TRB 
TCL -#-§ 
-BCLK 
(ON IPSB 
' 
BUS) 
TSK 
<-- TBCH 
TBCL 
4- Tn 
TF 


BBCLK 
I‘ 
5 0 
TOFF 
TON 


QUTPUTS 
Other Source ->- 4 
VALID 
It-> 
Other Source 


TCP 
TIH 


"‘"’“T8. 
<—' 
Tsu 


Notes: 
4. Minimum turn-on times are measured the same way as hold times. Specifically, the logic level driven by another device on the 
previous clock cycle must not be disturbed. 
5. Maximum turn-off times are measured to the condition where the output leakage current becomes less than the input leakage 
specification. 
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S 


Applied Output 
Voltage 
-0.3 V to VCC +0.5 V 


Applied Input 
Voltage 
-0.5 V to VCC +0.5 V 


DC CHARACTERISTICS TA = 0 c to + 70 c, vcc = 5 v 5% 


Symbol 
Parameter 


VIL 


VIH 


VOL 


VOH 


ILI 


IOL 


IOH 


ICC 


CAPACITANCETA = 25 c, 1c = 1 MHz ( Note 1) 


Symbol 


COC 


Note: 
I 


1 . Periodically sampled rather thanf 00% tested. 
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In ut Low Volta e 
P 
9 


Input High Voltage 
VCC + 0.5 


Output Low 
Open Drain 


V°'tag° 
All Others 
0 45 


Out ut Hi h Volta e 


Open Drain 


BBCLK 
zt 1 


All Others 


O en Dra 


:I: 400 
Input Leakage 
Current 


°8iP8i L°W 
ADDIR and 
CUTTGIII 
_RE|:ADR 


AIIO es 


OututHih 
r 


Operat 
Current 
ing Supply 


Parameter 


—L(J1 


"D‘O"D 
"D 


BBCLK 


All Others 
Input Capacitance 


I/O Capacitance 
9Q0 


Output Capacitan 


VL82C389 


ABSOLUTE MAXIMUM 
RATINGS 


Ambient Operating 
- 
Stresses above those listed may cause 
8|'lB6i is I101 ImP|i6d- EXPPSUTP 1° 
Tgmpefatufg 
-10°C IO +80°C 
permenem damage re the device, These 
absolute maximum rating conditions for 


O 
O 
are stress ratings only, and operation of 
9Xi90d9d P9Ti°d$ mall affect d°V'°° 
Storage Temperature 
_65 C to +150 C 
this device at these or other cxanditions 
reliablity. 
SUPPIY Voltage to 
above those indicated in this data 
Ground Potential 
-0.5 V to +7.0 V 


Test Condltlons 


IOL Max 


IOL Max 


IOH Max 


0 5 VIN 5 VCC 


0 5 VIN 5 VCC 


0 5 VIN 5 VCC 


VOL = 0.55 V 


VOL = 0.45 V 


VOL = 0.45 V 


VOH ... 2.4 V 


Test Condltlons 
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FEATURES 
DESCRIPTION 
- Compatible with 8086, 8088, and 
The VL82C59A Programmable Interrupt 
similar microprocessors 
Controller can manage up to eight 


_ L 
- 
- 
vectored priority interrupts for the 
ow power consuming CMOS 
system's CPU. It can be cascaded to 
° IPIPTTUPI m°d°$ ale PT°9TammaPI° 
handle up to 64 interrupts. No additional 


- Minimizes software overhead 
°"°“'"Y ‘S '°q“"ed- 


- Eight prioritized control levels 
Th? VL82C59A has been designed Io 
__ 
relieve the software of the burden of 
' 54 I9‘/9'3 °I °XPa"daP'I'iY 
handling multi-level priority interrupts. It 
. 
3ing|9 5 V power supp“, 
controls several modes, permitting 
optimization for a large number of 
~ 
28-pin DIP Packa e 
9 
system needs. 


PROGRAMMABLE INTERRUPT CONTROLLER 


The VL82C59A is fully upward compat- 
ible with the HMOS 8259 or 8259A. 
Software originally written for the HMOS 
8259 or 8259A will operate the 
VL82C59A in all 8259 or 8259A 
equivalent modes. 


The VL82C59A is housed in a 28-pin 
DIP, uses CMOS technology and 
requires a single 5 V supply. The circuit 
is totally static, requiring no clock input. 


PIN DIAGRAM 
BLOCK DIAGRAM 
INT 


VL82C59A 


-CS1 
—WR2 
-RD3 
D74 
D65 
D56 
D47 
D38 


D2 I19 
D110 


D0 I 11 
CAS012 
CAS113 


GND 
14 


D7 


05 
5 
05 
5 
04 
7 
03 
e 
02 
9 
0110 
11 
DO 
121 3 


VCC 


A0 


28 I 


27 . 


25||-JNTA 


25 I IR7 


24 - 
IR6 


23 I lR5 


22 I IR4 


21 I IR3 


20 I lR2 


19 . IR1 
18lllRO 


17 I INT 


16 I -SP/-EN 


15 I CAS2 


—RD 
-—CS 
A0 


1-I PI ~.§ 


o—~I— 
5.§B.- iiil 5 I 


TOP VIEW 


mo 
lR1—> INTERRUPT 
TN 
FtEAP/ 
' 
REQUEST 
PRIORITY 
SERVICE 
WW5 
REG 
RESOLVER REG 
'-°G'° 
IR2-——> 
IRS —-> 
IR4 —> 
lR5 —> 
lR6 —> 
IR7 '—> 


-INTA 


IR7 
24 
28 
22 
21 
20 
19lR1 


lR6 


ias 


IR4 


lR3 


lR2 


14 
15 
16 
17 
18 
I I I I I I I 
0As0 
GND 
-sP/ 
IRO 
-EN 
CAS1 
CAS2 
INT 


-RITA 


DATA 
CONTROL LOGIC 
H 
eus § 
00-07 
BUFFER 


1] 
f 


(IRB) ' 
I 
(ISR) 


INTERRUPT MASK REG 
<-> 
(IMR) 
§ 
CASCADE 
BUFFER! 
‘_’ 


INTERNAL BUS 


-no 
- 
-we 


A0 


-CS 


CASO 


CAS1 


CAS2 
COMPARATOR ,__, 


-SP/-EN 


ORDER INFORMATION 


Part 
Number 


VL82C59A-08PC 
VL82C59A-08QC 
VL82C59A-08CC 


VL82C59A-10PC 
VL82C59A-10QC 
VL82C59A-10CC 


Bus 
Speed 


8 MHz 


10 MHz 


Package 


Plastic DIP 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 


Plastic DIP 
Plastic Leaded Chip Carrier (PLCC) 
Ceramic DIP 


Note: Operating temperature range is 0°C to +70°C. 
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SIGNAL DESCRIPTIONS 
Slgnal 
Pln 
Slgnal 
Slgnal 
Name 
Number 
Type 
Descrlptlon 


-CS 
1 
I 
Chip Select - A low on -CS enables -RD and —WR communication 
between the CPU and the VL82C59A INTA functions are independent of 
—CS. 


—WR 
2 
O 
Write - A low on -WR when -CS is low enables the VL82C59A to accept 
command words from the CPU. 


-RD 
3 
I 
Read - A low on -RD when -CS is low enables the VL82C59A to release 
status onto the data bus for the CPU. 


D0-D7 
11-4 
l/O 
Bidirectional Data Bus - Control, status, and interrupt-vector information is 
transferred by this bus. 


CASO-CAS2 
12, 13, 15 
l/O 
Cascade Lines - The CAS lines form a unique VL82C59A bus to control a 
multiple VL82C59A configuration. These pins are outputs for a master 
VL82C59A and inputs for a slave VL82C59A. 


-SP/-EN 
16 
I/O 
Slave Program/Enable Buffer - The -SP/-EN pin provides a dual function. 
When in the Buffered Mode, it can be used as an output to control the 
buffer transceivers (EN). When not in the buffered mode, it is used as an 
input to designate a master (SP = 1) or a slave (SP = 0). 


INT 
17 
O 
Interrupt - The INT pin goes high whenever a valid interrupt request is 


- 
present. It is used to interrupt the CPU and is connected to the CPU's 
interrupt pin. 


lR0-IR7 
18-25 
I 
Interrupt Requests - Asynchronous inputs. An interrupt request is executed 
by raising an IR input (low to high) and holding it high until it is acknowl- 
edged (Edge Triggered Mode), by a high level on an IR input (Level 
Triggered Mode). 


-INTA 
26 
I 
Interrupt Acknowledge - The —lNTA pin is used to enable the VL82C59A’s 
interrupt-vector data onto the data bus by a sequence of interrupt acknowl- 
edge pulses issued from the CPU. 


A0 
27 
I 
A0 Address Line - The A0 pin acts together with the -CS, -WR, and -RD 
pins. It is used by the VL82C59A to decode various Command words the 
CPU writes and status the CPU needs to read. It is typically connected to 
the CPU A0 address line (A1 on the iAPX86, 88). 


VCC 
28 
l 
+5 V Supply 


GND 
14 
l 
Ground 
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FUNCTIONAL DESCRIPTION 
The VL82C59A has been designed to 
be used in real-time, interrupt-driven 
microcomputer systems. It controls 
eight levels or requests, and has a built- 
in feature for expandability to other 
VL82C59A’s (up to 64 levels). It is 
programmed by the system's software 
as an I/O peripheral. A selection of 
priority modes are usable by the pro- 
grammer so that the way in which the 
requests are handled by the VL82C59A 
can be configured to match the system 
requirements. The priority modes can 
be changed at any time during the main 
program. The entire interrupt structure 
can be defined as needed, based on 
the total system requirements. 


Interrupt Request Register (IRR) and ln- 
Service Register (ISR) - The interrupts 
at the IR input lines are handled by two 
registers in cascade, the Interrupt 
Request Register (IRR) and the ln- 
Service Register (ISR). The IRR stores 
all the interrupt levels which are 
requesting service, and the ISR stores 
all of the interrupt levels which are 
being handled. 


Priority Resolver - This logic block sets 
the priorities of the bits set in the IRR. 
The highest priority is selected and 
strobed into the corresponding bit of the 
ISR during the -INTA pulse. 


Interrupt Mask Register (IMR) - The 
IMR holds the bits which mask the 
interrupt lines. The IMR changes the 
IRR. Masking of a higher priority input 
will not affect the interrupt request lines 
of a lower priority. 


Interrupt (INT) - This output interfaces 
to the CPU interrupt input. The VOH 
level on this line has been designed to 
be fully compatible with the 8080A, 
8085A and 8086 input levels. 


Interrupt Acknowledge (-INTA) - The 
—lNTA pulses will cause the VL82C59A 
to release vectoring information onto 
the data bus. The format of this data 
depends on the system mode of the 
VL82C59A. 


Data Bus BufIer- This three-state, bidi- 
rectional 8-bit buffer is used to interface 
the VL82C59A to the system Data Bus. 
Control words and status information 
are transferred through the Data Bus 
Buffer. 


Read/Write Control Logic - The purpose 
of this block is to accept output com- 
mands from the CPU. It contains the 
Initialization Command Word (ICW) 
registers and Operation Command 
Word (OCW) registers. They store the 
various control formats for device 
operation. This function block also 
permits the status of the VL82C59A to 
be transferred onto the Data Bus. 


Chip Select (-CS) - A low on this input 
enables the VL82C59A. Reading or 
writing of the chip will not occur unless 
the device is selected. 


Write (—WR) - A low on this input 
permits the CPU to write control words 
(lCWs and OCWs) to the VL82C59A. 


Read (—RD) - A low on this input 
enables the VL82C59A to transmit the 
status of the Interrupt Request Register 
(IRR), In-Service Register (ISR), the 
Interrupt Mask Register (IMR), or the 
interrupt level to the Data bus. 


Cascade Buffer/Comparator - This 
function block stores and compares the 
identities of all VL82C59A’s used in the 
system. The three I/O pins (CASO- 
CAS2) are outputs when the VL82C59A 
functions as a master and are inputs 
when the VL82C59A functions as a 
slave. As a master, the VL82C59A 
sends the identity of the interrupting 
slave device onto the CASO-CAS2 
lines. The slave selected can now send 
its preprogrammed address to the Data 
Bus during the next cxansecutive -INTA 
pulses. 


Interrupt Sequence - Interrupt routine 
addressing is a very important aspect of 
VL82C59A operation, as is device 
programmability. Interrupt routine 
addressing permits direct or indirect 
jumping to the specific interrupt routine 
requested with no polling of the inter- 
rupting devices. The activities occurring 
during an interrupt depends on the type 
of CPU being used. 


The events occur as shown below in an 
MCS 80/85 system: 


1. Interrupt Request lines (IRO-IR7) are 
raised high, setting the correspond- 
ing IRR bit(s). 


2. The VL82C59A evaluates these 
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requests, then sends an INT to the‘ 
CPU, if necessary. 


3. The CPU acknowledges the INT and 
responds with the —lNTA pulse. 


4. When receiving an -INTA from the 
CPU group, the highest priority ISR 
bit is asserted, and the proper IRR 
bit is reset. The VL82C59A will also 
send a CALL instruction code 
(1 1001101) to the 8-bit Data Bus 
through its D0-D7 pins. 


5. The CALL instruction will initiate two 
additional -INTA pulses which will 
be sent to the VL82C59A from the 
CPU group. 


6. The two —lNTA pulses permit the 
VL82C59A to send its prepro- 
gram med subroutine address to the 
Data Bus. The lower 8-bit address 
is sent at the first -INTA pulse and 
the higher 8-bit address is sent at 
the next -INTA pulse. 


7. The 3-byte CALL instruction sent by 
the VL82C59A is then completed. In 
the AEOI mode, the ISR bit is reset 
at the end of the third -INTA pulse. 
If not, the ISR bit remains set until 
an appropriate EOI command is 
issued at the end of the interrupt 
sequence. 


The sequence of events occurring in an 
iAPX86-type system are the same until 
step 4. The sequence then continues: 


4. When receiving an -INTA from the 
CPU group, the highest priority ISR 
bit is set and the corresponding IRR 
bit is reset. The VL82C59A does 
not use the Data Bus during this 
cycle. 


5. The iAPX 86/10 will send a second 
-INTA pulse. During this second 
pulse, the VL82C59A releases an 8- 
bit pointer to the Data Bus and it is 
read by the CPU. 


6. The interrupt cycle is then complete. 
In the AEOI mode the ISR bit is 
reset at the end of the second 
-INTA pulse. If not, the ISR bit 
remains set until a valid EOI com- 
mand is sent at the end of the 
interrupt subroutine. 


If there is no interrupt request present at 
step 4 of either sequence (i.e., the 
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request duration was too short) the 
VL82C59A will send an interrupt level 7. 
Both the vectoring bytes and the CAS 
lines will appear as though an interrupt 
level 7 was requested. 


INTERRUPT SEQUENCE OUTPUTS 
FOR MCS-80° & MCS-85° 
This sequence is timed by three -INTA 
pulses. During the first -INTA pulse the 
CALL opcode is enabled onto the Data 
Bus. 


CONTENTS OF FIRST INTERRUPT 
VECTOR BYTE 


CALL 
or oe os o4 oa o2 o1 oo 
QPCQDE IIIIIIEIIIIIIIII 


During the second —lNTA pulse the 
lower address of the selected service 
routine is enabled to the data bus. 
When the interval = 4 address bits A5- 
A7 are programmed, while addresses 
A0-A4 are automatically inserted by the 
VL82C59A. When interval = 8 only A6 
and A7 are programmed, while A0-A5 
are automatically inserted. 


CONTENT OF SECOND INTERRUPT 
VECTOR BYTE 


EHIEIER 
HE 
HEIDI! 
IIIIIIIIII 
EIIIIIII 
EEIIIEIEI 
EIEIEIII 
EIIIIIIIIIII 
I13 
-EEEEIEEHEE 
Iilill 
HIIIIIIIIII 
BIIIIIIEII 
IJIIIIIEII 
EIIIIIEEI 
HIIIIIIIIH 
IIIIIHIIIIII 
IIIIIIIIIIIIIII 


iii 
EHEE 
6 
IIH 
A7 
IIIIEI 


During the third INTA pulse, the higher 
address of the correct service routine- 
programmed as byte 2 of the initializa- 
tion sequence (address lines A8-A15)- 
is enabled to the bus. 


CONTENT OF THIRD INTERRUPT 
VECTOR BYTE 


D7 
D6 
D5 
D4 
D3 
D2 
D1 
DO 


INTERRUPT SEQUENCE OUTPUTS 
FOR lAPX86° & iAPX88’ 
iAPX 86 mode is the same as the MCS- 
80 mode, with the exception that only 
two interrupt acknowledge cycles are 
issued by the processor and no CALL 
opcode is sent to the processor. The 
first interrupt acknowledge cycle is like 
that of MCS-80, 85 systems in that the 
VL82C59A uses it to internally hold the 
state of the interrupts for priority 
resolution. As a master, it issues the 
interrupt code on the cascade lines at 
the termination of the INTA pulse. On 
this first cycle, it does not send any data 
to the processor. It leaves its Data Bus 
buffers disabled. On the second 
interrupt acknowledge cycle (in iAPX86 
and iAPX88 modes) the master (or 
slave) will send a byte of data to the 
processor with the acknowledged 
interrupt code as follows (The state of 
the ADI mode control is ignored and 
address lines A5-A11 are unused in 
iAPX86 and iAPX88 mode.): 


CONTENT OF INTERRUPT VECTOR 
BYTE FOR iAPX86, iAPX88 
SYSTEM MODE 
IEHEEEEIEE 
IEEII 
IEEEI 
IEHEIII 
IEEIEI 
IEEEIIIIII 
IEIIEIII 
IEEEIEIII 


PROGRAMMING 
The VL82C59A uses two types of com- 
mand words generated by the CPU: 
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1. Initialization Command Words 
(lCWs): Before normal operation 
begins, each VL82C59A in the 
system should be brought to a 
starting point. This is done by a se- 
quence of 2 to 4 bytes timed by -WR 
pulses. 


2. Operation Command Words 
(OCWs): OCWs are the command 
words which command the 
VL82C59A to operate in various 
interrupt modes. These modes are: 


A. Fully nested mode 


B. Rotating priority mode 


C. Special mask mode 


D. Polled mode 


The OCWs may be written into the 
VL82C59A anytime following initializa- 
tion. 


Initialization Command Words (ICWS) - 
When a command is issued with 
address line A0 = 0 and D4 = 1, this is 
decoded as Initialization Command 
Word 1 (ICW1). ICW1 commences the 
initialization sequence during which the 
following occurs: 


A. The edge sense circuit is reset. 
Following initialization, an interrupt 
request (IR) input should make a 
low-to-high transition to generate an 
interrupt. 


B. The Interrupt Mask Register is 
cleared. 


C. IR7 input is assigned priority 7. 


D. The slave mode address is set to 7. 


E. Special Mask Mode is cleared and 
Status Read is set to IRR. 


F. If IC4 -= 0, allfunctions that were 
selected in ICW4 are set to zero. 
(Non-Buffered mode, no Auto-EOI, 
MCS-80 and MCS-85 system. 
Master/Slave in ICW4 is only used in 
the buffered mode.) 


Initialization Command Words 1 and 2 
(ICW1, ICW2) - A5-A15: Page starting 
address of service routines. In an 
MCS80/MCS85 system, all eight 
request levels will generate CALLs to 
eight locations equally separated in 
memory. These can be programmed to 
be separated at intervals of four or eight 
memory locations. The eight routines 
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will then occupy a page of 32 or 64 
bytes, respectively. 


The address format is 2 bytes in length 
(A0-A15). When the routine interval is 
4, A0-A4 are inserted by the 
VL82C59A, while A5-A15 are externally 
programmed. When the routine interval 
is 8, A0-A5 are inserted by the 
VL82C59A, while A6-A15 are externally 
programmed. 


The 8-byte interval will maintain 
compatibility with software presently 
being used, while 4-byte interval should 
be used for a small jump table. 


In an iAPX86 and iAPX88 system 
address lines A15-A11 are inserted in 
the five most significant bits of the 
vectoring byte and the VL82C59A sets 
the three least significant bits in 
accordance with the interrupt level. 
A10-A5 are ignored and ADI (Address 
Interval) is not used. 


LTIM: If LTIM =- 1, the VL82C59A will 
operate in the level interrupt mode. 
Edge detection logic on the interrupt 
inputs will be disabled. 


ADI: CALL address interval. ADI = 1 
then interval = 4; ADI = 0 then interval = 
8. 


SNGL: Single. This indicates that only 
one VL82C59A is in the system. If 
SNGL = 1 no lCW3 will be issued. 


IC4: If this bit is set, ICW4 must be 
read. If ICW4 is not used, set IC4 = 0. 


Initialization Command Word 3 (lCW3) - 
This word indicates that there is more 
than one VL82C59A in the system and 
cascading is used (SNGL = 0). It will 
load the 8-bit slave register. The 
functions of this register are below: 


A. In the master mode (either when SP 
= 1, or in buffered mode when M/S = 


1 in ICW4) a “1” is set for every 
slave in the system. The master will 
release byte 1 of the CALL se- 
quence (for MCS80/MCS85 system) 
and will then enable the correspond- 
ing slave to release bytes 2 and 3 
(for iAPX86, iAPX88 only byte 2) 
through the cascade lines. 


B. In the slave mode (either when —SP 
=0,orifBUF=1 and M/S=0in 
ICW4) bits 2-0 identify the slave. 


The slave compares its cascade 
input with these bits. If they are 
equal, bytes 2 and 3 of the CALL se- 
quence (or just byte 2 of iAPX86, 
iAPX88) are released by it on the 
Data Bus. 


Initialization Command Word (ICW4) - 
SFNM: If SFNM =- 1, the special fully 
nested mode is programmed. 
' 


BUF: If BUF = 1, then the buffered 
mode is programmed. In buffered 
mode -SP/-EN becomes an enable 
output and the master/slave selection is 
made by M/S. 


M/S: 
M/S =- 1 indicates the VL82C59A 
is a master, M/S = 0 indicates the 
VL82C59A is a slave. If BUF = 0, M/S 
has no meaning. 


AEOI: If AEOI -= 1,then the automatic 
end of interrupt mode is programmed. 


Microprocessor mode: uPM = 0 sets 
the VL82C59A for MCS80, MCS85 
system operation. |.1PM = 1 sets the 
VL82C59A for iAPX86 system opera- 
tion. 


Operation Command Words (OCWs) - 
After the initialization Command Words 
(ICWs) are programmed into the 
VL82C59A, the chip is prepared to 
accept interrupt requests on its inputs. 
During VL82C59A operation, a selec- 
tion of algorithms can command the 
VL82C59A to operate in different 
modes through the Operation Com- 
mand Words (OCWs). 


OPERATING CONTROL WORDS 
(OCWs) 


OCW1 
A0 
D7 
D6 
D5 
D4 
D3 
D2 
D1 
D0 
III 


OCW2 
A0 
D7 
D6 
D5 
D4 D3 D2 
D1 
D0 
El mlzalun 


. 
OCW3 
A0 
D7 
D6 
D5 
D4 D3 D2 
D1 
D0 
El 


Operation Control Word (OCW1) - 
OCW1 sets and clears the mask bits in 
the interrupt Mask Register (IMR). M7- 
M0 cxantrol the eight mask bits. M = 1 
indicates the channel is masked , M = 0 
indicates the channel is enabled. 
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Operation Control Word 2 (OCW2) - R, 
SL, EOI - These three bits control the 
Rotate and End of Interrupt modes and 
their combinations. A drawing of these 
combinations can be found on the 
Operation Command Word Format, 
Figure 3. 


L2, L1, L0 - These bits determine the 
interrupt level responded to when the 
SL bit is active. 


Operation Control Word 3 (OCW3) 
ESMM - Enable Special Mask Mode. 
When this bit is set to 1 it enables the 
SMM bit to set or reset the Special 
Mask Mode. When ESMM = 0 the 
SMM bit is a “don‘t care”. 


SMM - Special Mask Mode. If ESMM .- 


1 and SMM = 1 the VL82C59A will 
enter Special Mask Mode. If ESMM = 1 
and SMM = 0 the VL82C59A will revert 
to normal mask mode. When ESMM = 
0, SMM is not used. 


FIGURE 1. INITIALIZATION 
SEQUENCE 


NO (swer. .. 1) 
IN 
CASCADE 
Moos 


YES (SNGL - 0) 


NO (|c4 . 0) 


YES (|c4 . 1) 


READY TO ACCEPT 
INTERRUPT REQUESTS 
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FIGURE 2. 
INITIALIZATION COMMAND WORD FORMAT 


ICW1 


TIM 
SNGL 


O 
H> IE5‘E8 
ErIEI8 


UN 
E-'2 
8 


1 


ICW2 


Id“ 


G 
>-U 
> 
.5“ 


> 
IE5’.59 


Z0 


IIR!“ 


NI 
ON 


O 


|CW3 ( MASTER DEVICE) 


A0 
D7 
D6 
D5 
D4 
D3 
IBBBB 


ICW3 (SLAVE DEVICE) 


A0 
D7 
D6 
D5 
D4 
D3 
D2 
D1 
D0 


A0 
D7 
D6 
D5 
D4 
D3 
D2 
D1 
D0W 


Note: 
Slave ID is equal to the corresponding master IR input. 
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1 
ICW4 needed 
0 
No ICW4 needed 


1 =S| gle 
0 = Cascade mode 


CALL ADDRESS INTERVAL 
1 = Interval of 4 
0 
Interval of 8 


1 =Level triggered mode 
0 
Edge triggered mode 


A7 through A5 of 
Interrupt vector address 
(MCS 80 85 mode only) 


A15 through A8 of 
' 
interrupt vector address 
(MCS-80, 85 mode) 
T 7 through T 3 of 
interrupt vector address 
(8086, 8088 mode) 


1 IR input has a slave 
0 IR input does not have a slave 


II 
BBIEEBBEEBEENBEBE 


WERE 
WHEN 
EDEN 
ll! 


1 =8086, 8088 mode 
0 = MCS-80, 85 mode 


1 
Auto EOI 
0 
Normal EOI 
EI Non-buffered mode 
I-11 Buffered mode slave 
I--I Buffered mode master 


1 = Special fully nested mode 
0 = Not special fully nested mode 
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FIGURE 3. OPERATION COMMAND WORD FORMAT 


OCW1 
o 


> 


U 


IIIEEI“ 
UN 
ow 
UI 
U1 


U 


liil“ 
UI 
co 
UI 
|\> 
g 


o 


INTERRUPT MASK 


1 = Mask set 
0 = Mask reset 
OCW 2 


D6 
D5 
D4 
D3 
D2 
D1 
D0 


IR LEVEL TOIBE ACTED UPON 
HIIHBE 
IIIIEIIIEIIIEIII 
HIIEIIIIIII 


Illl 


>o 
U\I 
.!' 


HJLHLF 
“E 


:°n'i?e:2; EOI oomgmnd 
End of interrupt 


1 
peci IC 
comman 
ERotate on non-specific EOI command 


Rotate in automatic EOI mode (set) 
AUI°maII¢ "°taII°" 


Rotate In automatic EOI mode (clear) 
n‘Rotate on specic EOI command 


‘Set priority command 


No operation 


Specific rotation 


‘L 0 - L 2 are used. 


ocwa 
_ 
A0 
D7 
D6 
D5 
D4 
D3 
D2 
D1 
D0 
Il 


READ REGISTER COMMAND 
lIIIII—IB 


IIII 
Read IR 
Read IS 
No Action 
F199 on 
Ree on 
next 
RD next—RD 
pulse 
pulse 


1 = Poll command 
0 = No poll command 


SPECIAL MASK MODE 


Reset 
e 
No Action 
special 
special 
mask 
mask 
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MODES 
Fully Nested Mode - This is the default 
mode after initialization unless another 
mode is programmed. The interrupt 
requests are ordered in priority from 0 
through 7 (0 highest). When an 
interrupt is acknowledged, the highest 
priority request is decoded and its 
vector placed onto the bus. A bit of the 
Interrupt Service register (ISO-IS7) is 
also set. This bit stays set until the 
microprocessor issues an End of 
Interrupt (EOI) command before 
returning from the service routine. It 
also stays set if the AEOI (Automatic 
End of Interrupt) bit is set, until the 
trailing edge of the last INTA. While the 
In-Service (IS) bit is set, all further 
interrupts of the same or lower priority 
are disabled. Higher levels will gener- 
ate an interrupt. 


After the initialization sequence, lR0 
has the highest priority and IR7 the 
lowest. Priorities may be be changed 
in the rotating priority mode. 


End of Interrupt (EOl)- The In-Service 
(IS) bit may be reset either automati- 
cally following the trailing edge of the 
last in sequence —INTA pulse (when 
AEOI bit in ICW1 is set), or by a 
command word that should be issued to 
the VL82C59A before returning from a 
service routine (EOI command). An 
EOI command is issued twice if in the 
Cascade mode, once for the master 
and once for the corresponding slave. 


Two forms of an EOI command are 
used; Specific and Non-Specific. 
When the VL82C59A is operated in 
modes which maintain the fully nested 
structure, it can determine which IS bit 
to reset on EOI. When a Non-Specific 
EOI command is sent the VL82C59A 
will reset the highest lSbit of those that 
are set. In the fully nested mode the 
highest IS level was necessarily the last 
level operated upon. A Non-Specific 
EOI can be sent with OCW2 (EOI = 1, 
SL = 0, R = 0). 


When a mode may change the fully 
nested structure, the VL82C59A may 
not be able to determine the last level 
responded to. A Specific End of 
Interrupt must then be issued, which 
includes IS level to be reset as part of 
the command. A Specific EOI can be 
sent with OCW2 (EOI = 1, SL = 1, R = 


0, and L0-L2 is the binary level of the IS 
bit to be reset). 


When the IS is masked by an IMR bit, it 
will not be cleared by a Non-Specific 
EOI, if the VL82C59A is in the Special 
Mask Mode. 


Automatic End of Interrupt (AEOI) Mode 
- If AEOI = 1 in ICW4, then the 
VL82C59A will operate in AEOI mode 
until changed by ICW4. In this mode, 
the VL82C59A will perform a Non- 
Specific EOI operation at the trailing 
edge of the last interrupt acknowledge 
pulse. This mode should be used only 
when a nested multilevel interrupt 
structure is not required in a single 
VL82C59A. 


The AEOI mode can only be used in a 
master VL82C59A. 


Automatic Rotation (Equal Priority 
Devices) - In many applications there 
are several interrupting devices of equal 
priority. In this mode the device 
receives the lowest priority. A device 
requesting an interrupt will wait, in the 
worst case, until each of seven other 
devices with higher priority are serviced. 
If the priority and "in service” status is: 


Before Rotate (IR4 the highest priority- 
requiring service) 


“|S_ 
lS7 
I86 
ISS 
IS4 
ISS 
IS2 IS1 
ISO 
Status BIEIIIEIII 


Lowest Priority 
Highest Priority 


§{ii’t{§§.' 
uunuuu 


After Rotate (IR4 was serviced): 


__|S_ 
IS7 
lS6 
iss 
IS4 
IS3 
IS2 IS1 
iso 
Status EIIIEIIIEIEIEIB 


Highest Priority 
Low stPriority 
P ' 
"t 
- 
£11.’ ulluul-inn 


There are two ways to accomplish 
Automatic Rotation using OCW2, the 
Rotation on Non-Specific EOI Com- 
mand (R = 1, SL= 0, EOI = 1) and the 
Rotate in Automatic EOI Mode which is 
set by (R =1, SL = 0, EOI = 0) and 
cleared by (R = 0, SL = 0, EOI = 0). 


Specific Rotation (Specific Priority) - 
The programmer may change priorities 
by programming the bottom priority and 
thereby fixing all of the other priorities 
(e.g., if IRS is programmed as the 


bottom priority device, then IR6 will be 
the highest one). 


The Set Priority command is issued in 
OCW2 where: R - 1, SL = 1; L0-L2 is 
the binary priority level code of the 
bottom priority device. 


In this mode internal status is updated 
by software control during OCW2. It is 
independent of the End of Interrupt 
(EOI) command. Priority changes may 
be performed during an EOI command 
by using the Rotate on Specific EOI 
command in OCW2 (R = 1, SL = 1, EOI 
= 1, and L0-L2 = IR level to receive 
bottom priority). 


Interrupt Masks - Each Interrupt 
Request input may be masked individu- 
ally by the lnterrupt Mask Register 
(IMR) by programming OCW1. Each bit 
in the IMR masks one interrupt channel 
when it is set (1). Bit 0 masks lR0, bit 1 
masks IR1, etc. Masking an IR channel 
has no affect on the other channels 
operation. 


Special Mask Mode - Some applications 
will require an interrupt service routine 
to change the system priorities during 
its execution under program control. 
The routine may need to inhibit lower 
priority requests for a portion of its 
execution, but enable some, for another 
portion. 


If an Interrupt Request is acknowledged 
and an End of Interrupt command did 
not reset the IS bit during a service 
routine, the VL82C59A will inhibit all 
lower priority requests without a simple 
routine to enable them. 


In the Special Mask Mode, a mask bit 
set in OCW1 inhibits further interrupts at 
that level and enables interrupts from all 
other levels that are not masked. 


Any interrupts may be enabled selec- 
tively by loading the mask register. 


The Special Mask Mode is set by 
OCW3 when: SSMM = 1, SMM =- 1, 
and cleared where SSMM = 1, SMM = 
0. 


Poll Command - In this mode the INT 
output is disabled or the microprocessor 
internal Interrupt Enable flip-flop is 
reset, disabling its interrupt input. 
Service to devices is programmed by 
software using a Poll command. 
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The Poll command is issued by setting 
P =1 "1" in OCW3. The VL82C59A 
treats the next -RD pulse to the 
VL82C59A (i.e., -RD == 0, —CS = 0) as 
an interrupt acknowledge, sets the 
appropriate IS bit if requested and 
reads the priority level. Interrupt is 
frozen from -WR to —RD. 


The word enabled to the data bus 
during -RD is: 


D7 
D6 
D5 
D4 
D3 
D2 
D1 
D0 
IIEEEE 


W0-W2: Binary code of the highest 
priority level requesting 
service. 
1: Equal to a '1" if there is an 
interrupt. 


This mode is most useful when there is 
a routine command common to several 
levels. Then the -INTA sequence is not 
needed. It is frequently useful to expand 
the number of priority levels to more 
than 64. 


VL82C59A STATUS 
The input status of several internal 
registers can be read to update user 
information from the system. The 
following registers can be read by using 
OCW3 (IRR and ISR or OCW1(lMR)). 


Interrupt Request Register (IRR): 8-bit 
register which contains the levels 
requesting an interrupt to be acknowl- 
edged. The highest request level is 
reset from the IRR when an interrupt is 
serviced. (Not affected by IMR.) 


In-Service Register (ISR): 8-bit register 
which contains the priority levels that 
are being updated. The ISR is changed 
when an End of Interrupt Command is 
sent 


Interrupt Mask Register: 8 bit register 
which contains the interrupt request 
lines which are masked. 


The IRR may be read when, prior to the 
—RD pulse, a Read Register Command 
is sent with OCW3 (RR = 1, RIS = 0). 


The ISR may be read when, prior to the 
—RD pulse, a Read Register Command 
is sent with OCW3 (RR= 1, RIS - 1). 


OCW3 is not written before every status 
read operation, as long as the status 
read corresponds with the previous one. 


FIGURE 4. PRIORITY CELL-SIMPLIFIED LOGIC DIAGRAM 


LTIM BIT 
TO OTHER PRIORITY CALLS 
0 - EDGE,1 = LEVEL 
Cm '8“ 


EDGE 
SENSE 
LATCH 
ii-‘Lin ISR BIT 


SET 


SET ISR 


PRIORITY 
CLB 
RESOLVER 
Q 


5 
'5 
.: I 
1 


-INTA 


-FREEZE 


MCS-80, 85 
MODE 


REQUEST 
LATCH 
> 
D-Q 
. 
I 
° 
REQ 


C 
Q 
0Q 


c 


-FREEZE 
READ IRR 
MASTER CLR 
READ IMR 


CONTROL 
LOGIC 
NON 
MASKED 


INTERNAL DATA BUS-P 


_|NTA 
WRITE MASK 
READ ISR 


TRUTH TABLE FOR D LATCH 
-FREEZE 
NOTES: 


1. Master clear active only during ICW1 
C 
Operation 
|Apx B5 
2. FREEZE! is active during -lNTA/ and 
1 
Follow 
Moog 
poll sequences only 
O u 
Hold 
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The VL82C59A retains whether the IRR 
or ISR has been previousl selected b 
Y 
Y 
the OCW3. This is untrue when the poll 
is used. 


After initialization, the VL82C59A is set 
to IRR. 


For reading the IMR, no OCW3 is 
needed. The output data bus will 
contain the IMR when —RD is active and 
A0 = 1 (OCW1). 


Polling overrides a status read when P 
= 1, RR -1 in OCW3. 


Edge and Level Triggered Modes - This 
mode is selected using bit 3 in ICW1. 


If LTIM = 0, an interrupt request will be 
recognized by a positive-going transi- 
tion on an IR input. The IR input may 
stay high without generating another 
interrupt. 


If LTIM = 1, an interrupt request can be 
recognized by a high level on IR input 
and there is no requirement for edge 
detection. The interrupt request should 
be disabled before the EOI command is 
issued or the CPU interrupt is enabled 
to preclude a second interrupt from oc- 
curring. 


Figure 4, shows a basic circuit of the 
level sensitive and edge sensitive input 
circuitry of the VL82C59A. The request 
latch is a "D" type latch, which is 
transparent. 


In the edge and level triggered modes, 
the IR inputs should stay high until after 
the falling edge of the first INTA. 
If the 
IR input goes low before this time, a 
default IR7 occurs when the CPU 
responds to the interrupt. This may 
detect interrupts generated by noise on 
the IR inputs. The IR7 routine is used 
for smoothing by simply executing a 
return instruction thus ignoring the 
interrupt. If IR7 is needed for other 
purposes a default IR7 can still be 
detected by reading the ISR. A normal 
IR7 interrupt will set the corresponding 
ISR bit, a default IR7 will not. If a 
default IR7 routine occurs during a 
normal IR7 routine, the ISR will remain 
set. It is necessary to record whether or 
not the IR7 routine was previously 
entered. If another IR7 occurs, it is a 
default. 


The Special Fully Nested Mode - This 
mode can be used for a big system, 
where cascading occurs, and the 


priority has to be saved by each slave. 
Using ICW4, t1qhe fully nested mode 
will be programmed to the master. This 
mode is the same as the normal nested 
mode, except as follows: 


A. When an interrupt request from a 
given slave is in service, the slave is 
not locked out from the master's 
priority logic. Further interrupt 
requests from higher priority lR’s 
within the slave will be recognized 
by the master and will initiate 
interrupts to the processor. In the 
normal nested mode a slave is 
masked out when its request is in 
service and no higher requests from 
the same slave can be handled. 


B. When exiting the Interrupt Service 
routine, the software has to insure 
that the interrupt serviced was the 
only one from the slave. This is 
accomplished by sending a Non- 
Specific End of Interrupt (EOI) 
command to the slave, then reading 
its In-Service register and checking 
for zero. If empty, a Non-Specific 
EOI may be sent. If not, no EOI 
may be sent. 


FIGURE 5. 
IR TRIGGERING TIMING REQUIREMENT 


IR 


INT 


INTA 


8086/8088 
8080/8085 I 


8086/8088 
Y 
8080/8085 


LATCH‘ 
EARLIEST IR 
LATCH‘ 
ARMED 
CAN BE MOVED 
ARMED 


‘Edge Triggered Mode Only 
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Buffered Mode - When the VL82C59A 
is used in a large system and bus 
driving buffers are needed, on the data 
bus (when the cascading mode is used) 
enabling buffers may cause difficulty. 


The buffered mode will structure the 
VL82C59A to send an enable signal on 
-SP/-EN to enable the buffers in this 
mode, when the VL82C59A data bus 
outputs are enabled, the -SP/-EN 
output is active. 


This change mandates the use of 
software programming to ascertain 
whether the VL82C59A is a master. Bit 
3 in ICW4 programs the buffered mode, 
and bit 2 in ICW4 decides whether it is 
a master or a slave. 


Cascade Mode - The VL82C59A may 
be interconnected in a system of a 
master with as many as eight slaves 
and handle up to 64 priority levels. 


The master controls the slaves by the 
three-line cascade bus. The cascade 
bus is like chip selects to the slaves 
during the -INTA. In a cascade con- 
figuration, the slave interrupt outputs 
are connected to the master interrupt 
request inputs. When a slave request 
line is asserted and then acknowledged 
the master will enable the slave to 
release the device routine address 
during bytes 2 and 3 of INTA. Byte 2 is 
only for 8086/8088—based systems. 


The cascade bus lines are normally low 
and contain the slave address wde 
from the falling edge of the first INTA 
pulse to the falling edge of the third 
pulse. All VL82C59As in the system 
must follow a separate initialization 
sequence. Each may be programmed to 
work in a different mode. An EOI 
command should be issued; once for 
the master, and once for the slave. An 
address decoder is needed to assert 
the Chip Select (CS) input of each 
VL82C59A. 


The cascade lines of the Master 
VL82C59A are asserted for slave 
inputs. Non-slave inputs let the cascade 
line remain inactive (low). 


FIGURE 6. CASCADING THE VL82C59A 


ADDRESS BUS (16) 


CONTROL BUS 


INT 
REQ 


DATA BUS (e) 
2!!!! 
|‘ mi 
-CS 
A0 
D0-7 
—INTA 
INT 
-CS 
A0 
D0-7 
-INTA 
INT 
-CS 
A0 
D0-7 
—INTA 
INT 


CASO 
VL82C59A 
SLAVE A 
CAS I 


CAS 0 
VL82C59A 
E 


BE E- 
OO 
AS 0 ,/ 
VL 
AS 1 
Mi§°1%°§ 
CAS2 
CAS2 
CAS2 


-SP/—EN7 
6 
5 
4 
3 
210 
-SP/—EN7 
6 
5 
4 
3 
210 
—-SP/-ENM7M6M5M4M3M2M1M0 


GND 
GND 
76543210 
76543210 


INTERRUPT REQUESTS 


654 
3210 
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AC CHARACTERISTICS: TA = osc to +1o<>c, vcc = s v =t1o% 


TIMING REQUIREMENTS 


VL82C59A 
VL82C59A 
-os 
-to 
_ 


tAHRL 


tRHAX 
A0/-CS Hold after -RD/-INTA High 


tRLRH 
-RD/-INTA Pulse Width 


tAHWL 
A0/-CS Setup to -WR Low 


IWHAX 
A0/-CS Hold after -WR High 


tWLWH 
-WR Pulse Width 


tDVWH 
Data Setup to -WR High 


tWHDX 
Data Hold after -WR High 


tJLJH 
Interrupt Request Width (Low) 


EEEE 
E-——E 
-E-B 
E-EEE 
EEE-E 
IBEEEE 
BEE-E 
EEEEE 
IBEEEE 


End of -RD to next -RD 
End of -INTA to next —lNTA 
150 
within an —lNTA sequence only 


E~d<=*—WRt<= next-WR 
BEEEE 


End of Command to Next Command 
(Not Same Command Type) 
End of —lNTA Sequence to Next -INTA 
Se uence 
Q 


Worst case timing for tCHCL in an actual microprocessor system is typically much greater than 400 ns 
(i.e. 8085A =- 1.6 us, 8085-A2 = 1 us, 80086 = 1 us, 8086-2 = 625 ns). 


tC\/‘AL 
Cascade_Setup to Second 


IRHRL 


IWHWL 


tCHCL‘ 


Note: This is the low time required to clear the input latch in-the edge triggered mode. 
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Symbol 
‘ Parameter 
Condltlons 


A0/-CS Setup to -RD/-INTA Low 


Note 
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TIMING RESPONSES 


Symbol 
Parameter 


tRLDV 
Data Valid from -RD/-INTA Low 


tR|-IOZ 
Data Float after -RD/-INTA High 


tJHlH 
Interrupt Output Delay 


Cascade Valid from First 
UALCV 
'-INTA Low (Master Only) 


Enable Active from -RD Low 
‘RLEL 
or -INTA low 


Enable Inactive from -RD High 
‘RHEH 
or -INTA High 


tAHDV 
Data Valid from Stable Address 


tCVDV 
Cascade Valid to Valid Data 


TEST CONDITION DEFINITION TABLE 


Test Condltlon 


17V 
523!) 


N-L 


_l 


4 5 V 
1 8 k 
1 8 k 


TESTING INPUT, OUTPUT WAVEFORM 


2.4 
2.0 
2.0 
> TEST POlNTS< 


' 
-10 
Iiii|mm@ 
E--E 
E--E 
---E 


C1 


100 pF 


30 pF 


TESTING LOAD CIRCUIT 
V1 


DEVICE 
UNDER 
TEST 


Condltlons 


1 


2 


1 


1 


1 


1 


1 


1 


R1 


TEST POINT 


Q_45 
0.8 
0.8 
R2 
I 
C1‘ 


AC testing inputs are driven at 2.4 V for a Logic 1 and 
‘Includes stray and jig capacitance. 
0.45 V for a Logic 0. Timing measurements are made 
at 2.0 V for a Logic 1 and 0.8 V for a Logic 0. 
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WRITE WAVEFORM 


tWLWH__> 
-ANR 


tAHWL 
tWHAX 


>o 
E 


‘ 
E 


V 


T 
—CS 
ADDRESS BUS 


tWHDX 


DATA BUS 


READIINTA WAVEFORM 


tRLRH 
-RD/-INTA 


-EN 
teneu 


tRHAX 
-CS 
ADDRESS BUS 
(I 
ii 
A0 


tRLDV 
tRHDZ 


tAHDV 


DATABUS _ - - _ - — - _ - _ _ -—- 
---—- 
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OTHER TIMING WAVEFORMS 


—RD 
-INTA 
tRHRL 


-we 


tWHWL 


-no 
-INTA 
-we 
tCHCL 
-no 
-INTA 
-we 


-INTA SEQUENCE WAVEFORM 


tJHIH 


IR 


tJLJH 


INT 


—INTA 


VL82C59A 


Gt) 


Q) 
C2) 
CD 


0- -------- 


tCVIAL 


C0-2 
IIALCV 
T 


Notes: 
Interrupt output must remain HIGH at least until leading edge of first INTA. 


1. Cycle 1 in iAPX 86, iAPX 88 systems, the Data Bus is not active. 
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ABSOLUTE MAXIMUM RATING 


Ambient Tempelawle 
Stresses above those listed may cause 
Under B188 
0°C 10 70° C 
permanent damage to the device. 
Sterege Temperature __65oC to +1 50°C 
These are stress ratings only, and func- 
tional operation of the device at these or 
I/05899 °" A")! PI" 
any other conditions above those 
with Respect to Ground 
-0.5 V to 7 V 


Power Dissipation 
1 Watt 


DC CHARACTERISTICS: 
TA = o<>c to rotc, vcc = s v 510% 


VL82C59A 


indicated in this data sheet is not 
implied. Exposure to absolute maxi- 
mum rating conditions for extended 
periods may affect device reliablility. 


VL82C59A 
VL82C59A 


1O 


Symbol 
Parameter 


nput Low Voltage 
-0 


5EFE 
SS C)310 
Ii- 


VCC-+-05 
Input High Voltage 


VOL 


VOH 
Output High Voltage 


Output Low Voltage 


VCC—04 
:I:0 


Output Leakage Current 
:t10 0 


IR Input Leakage Current 
-300 


Input Leakage Current 


+ 


CAPACITANCE: TA = 25° c, vcc = GND = o v 
SY'"b°' 
EEE 
°'" 
E 
°'/° 
EB 
°°“T 
EE 
Note: Capacitance values guaranteed and sampled, but not 100% tested. 


Operating Su 
Current 
pply 


ICCS 
Standby Supply Current 


Note: For extended termperature EXPRESS VIH = 2.3 V. 
' 
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1° EE 


Conditions 


IOL = 2.5 mA 


IOH = -2.5 mA 


IOH = -100 uA 


0 V 5 VIN 5 VCC 


0 V 5 VOUT 5 VCC 


VIN = 0 


VIN = VCC 


Note 


VIN = VCC or GND 


All IR = VCC 


Outputs Unloaded 


VCC = 5.5 V 


E 
E 
E 
E 
E 
E 
E 
I 


Test Condltlons 


fc = 1 MHz 


Unmeasured pins returned to VSS 
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FEATURES 
- Expands address lines from four to 12 


- Paged memory mapping design 


- Three-state or open-collector map 
outputs 


- Compatible with IBM PC/AT as well 
as most popular microprocessor- 
based systems 


- Single 5 V power supply 


- Low power-consuming CMOS 
technology 


- Fully compatible with 74LS612 


PC-AT MEMORY MAPPER (74LS612) 


DESCRIPTION 
The VL82C612 CMOS memory-mapper 
integrated circuit contains a 4-line to 16- 
line decoder, a 16-word by 12-bit RAM, 
16 channels of 2-line to 1-line multiplex- 
ers, and the necessary control logic to 
operate efficiently in an IBM PC/AT or 
most other microprocessor environ- 
ments. The device is fabricated in 
CMOS technology to insure low power 
consumption and maximum system 
performance while remaining fully 
compatible with the 74LS612. 


The memory-mapper expands the 
microprocessor’s system memory 


address capability by eight bits. Four 
bits of the memory address bus (see 
System Block Diagram below) can be 
used to select one of 16 map registers 
that contain 12 bits each. These 12 bits 
are presented to the system memory 
address bus through the map output 
buffers along with the remaining 
memory address bits from the CPU. 


The device is available in a 40-pin DIP 
as well as a 44-pin plastic leaded chip 
carrier (PLCC). 


PIN DIAGRAM 
SYSTEM BLOCK DIAGRAM 


RS2 
MA3 
RS3 
-CS 
-STB 
R/-W 


UUUUU8 
O1&(Jl\)—* 
-MM 
MOO 
MO1 
MO2 
MO3 
MO4 
MO5 
GND 


VL82C612 


8l.OCD\lO'>U‘l-l?~(JI\)--I- 


27 
26 
16 
25 
17 
18 
19 
20 


40 
39 
38 
37 
36 
35 
34 
33 
32 
31 


1 1 
30 
12 
29 


1 3 
28 
14 


1 5 


24 
23 
22 
21 


VCC 
MA2 
RS1 
MA1 
RSO 
MAO 
D11 
D10 
D9 
D8 
D7 
D6 
N.C. 
MO11 
MO10 
MO9 
MO8 
MO7 
MO6 
-ME 


PLEASE CONSULT DATA 
SHEET FOR DETAILED 
INFORMATION 



..I 
E->1 


SYSTEM 
MEMORY 
CONTROL 
D0-D11 
MAO- 
MO0- 
MA3 
VL82C612 
M9" 
MEMORY-MAPPER 


ADDRESS BUS 


ORDER INFORMATION 
Part 
Number 
Package 


VL32C612-PC 
Plastic DIP 
VL82C612-QC 
Plastic Leaded Chip Carrier (PLCC) 


Note: Operating temperature range is 0°C to +70°C. 
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FEATURES 
- Meets full Small Computer Systems 
Interface (SCSI) specifications for 
system cables up to six meters long 


- Fully buffered, bidirectional data and 
control buses 


- Interfaces directly to VL53C86 and 
NCR 5386 family 


- Can be used with other interfaces 
requiring a 48 mA drive 


- Low cost 


- Two-micron CMOS technology 


- Housed in a standard 52-pin PLCC 


GENERAL PURPOSE (SCSI) BUS TRANSCEIVER 


DESCRIPTION 
The VL83C11 General Purpose Bus 
Transceiver Chip, is a two-micron 
CMOS device designed as a 48 mA bus 
transceiver chip for all of the Small 
Computer System Interface (SCSI) bus 
signals. It incorporates high current 
single-ended drivers for the SCSI bus. 
The VL83C11 is specifically intended to 
be used with the VL53C86 or NCR 
53C86 SCSI Protocol Controller 
families. It interfaces directly to those 
devices, with no additional circuits 
required. It can be used with other 
interfaces where a general purpose 48 
mA bus transceiver is required. Logical 
and electrical flexibility also allow its use 


as a general pupose interface driverl 
receiver chip. 


The VL83C11 is functionally equivalent 
to the NMOS NCR 8310, but has been 
designed in CMOS technology. It meets 
the full electrical specifications of Small 
Computer Systems Interface (SCSI) for 
system cable lengths up to six meters 
long. Further, it has been optimized for 
connection to the standard SCSI 
connector. 


The VL83C11 General Purpose 
Tranceiver Chip is packaged in a 52-pin 
plastic leaded chip carrier (PLCC). 


PIN DIAGRAM 
BLOCK DIAGRAM 


VL83C11-QC 
esv 
esv 
vo 
use euo 
N 
our res 
T65 


IGS 
c/o 
ACK REQ 
SEI‘ 
85'} '51,?! 


Q 


~1- 
WE 
O1- 
Ji- 
OE 
NE 
ATN - 
RSTIN 
-—- 
9 
. 
-oeo I 
1o 


-DB1 
_ 
11 
-osz I 
12 
euo in 
13 
-css I 
14 
-cs-t in 
1s 
-css - 
1e 
euo -i 
17 
-oee - 
1e 
-oer I 
19 
-DBP n 
20 
21222324 2526 2728 2930 3132 33 
I I I I I I I I I I I I I 


D7 
D5 
D3 
D1 
D0 
—lD2 
-IDO 


D6 
D4 
D2 
VDD 
DP 


IGS 
I/0,0/D,MSG, 
6 
......‘ 
CONTROL 


1 52 s1 so 4e 4s 47 
RE°'AcK'ATN 
3 
BUS 
9 
46 I 
-ATN 
BUSYIN,SELIN, RSTIN E 
Clllliik $Q$|cQNTRQ|__ 
45 I 
—BSY 
44 I 
-ACK 
43 I 
GND 
42 I 
-RST 


41 I 
-MSG 
40 I 
-SEL 
39 I 
GND 
ARB 
38 I 
C/-D 
37 I 
-REQ 
36 I 
I/-0 
35 I 
—DBEN 
34 I 
ARB 


RSTOUT 


ORDER INFORMATION 


Part 
Number 
Package 


—IDC - -I02 E 


—DBEN 
I 


DATA 
9 


D0 -D7, DP E 
BUS 
E _DBQ - _.[)Bg' -DBP 


(—BSY, -SEL, -RST, 
BSYOUT, SELOUT, ii 
_ACK. _ATN. v_°. 


C/—D, -MSG, -REQ) 


ARBITRATION 
LOGIC 


VL83C11-QC 
Plastic Leaded Chip Carrier (PLCC) 
Note: Operating temperature range is 0°C to +70°C 
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SIGNAL DESCRIPTIONS 


Slgnal 
Pln 
Signal 
Name 
Number 
Descrlptlon 


-DBO - —DB7, 
-DBP 


-RST 


-ATN 


-ACK 


-REQ 


-MSG 


I/-O 


C/-D 


-SEL 


-asv 


D0, D1 -D7, DP 


-DBEN 


TGS 


IGS 


ARB 


-IDO-2 


I/O 


C/D 


MSG 


REQ 


ACK 


ATN 


BSYIN 


BSYOUT 


SELIN 


10-12, 14-16, 
18-20 


42 


46 


44 


37 


41 


36 


38 


40 


45 


29, 27- 21 
30 


35 


48 


7 


34 


33-31 


6 


5 


4 


1 


3 


8 


52 


50 


51 


These nine bits (-DBO through -DB7, -DBP) are bidirectional, active low, open-drain 
signals that form the data bus. -DB7 is the most significant bit and has the highest 
priority during Arbitration phase. Data parity is odd. Parity is not valid during arbitration. 


Reset - Indicates a SCSI bus reset condition. An “or-tied" signal. This signal is bidirec- 
tional, active low and open-drain. 


Attention - Driven by an initiator, -ATN indicates an attention condition. This bidirec- 
tional, active low and open-drain signal is received in the target role. 


Acknowledge - Driven by an initiator, -ACK indicates an acknowledgment for a REQ! 
ACK data transfer handshake. In the target role, -ACK is received as a response to the 
-REQ signal. It is a bidirectional, active low, open-drain signal. 


Request - Driven by a target, —REQ indicates a request for a REQ/ACK data transfer 
handshake. This signal is received by the initiator. It is a bidirectional, active low, open- 
drain signal. 


Message - Driven by the target during the Message phase. This bidirectional, active low, 
open-drain signal is received by the initiator. 


Input/Output - This bidirectional, open-drain signal is driven by a target which controls 
the direction of data movement on the SCSI bus. High indicates input to the initiator. 
This signal is also used to distinguish between Selection and Reselection phases. 


Control or Data - This bidirectional, open—drain signal is driven by the target. It indicates 
whether Control or Data is on the data bus. High indicates Control. This signal is 
received by the initiator. 


Select - Used by an initiator to select a target or by a target to reselect an initiator. It is a 
bidirectional, active low, open-drain signal. 


Busy - Indicates the SCSI bus is being used and can be driven by both the initiator and 
the target device. An "or-tied" signal. This is a bidirectional, active low, open-drain 
signal. 


These nine bits (D0 through D7, DP) form the data bus. D7 is the most significant bit 
and has the highest priority during Arbitration phase. DP is the parity bit. 


Data Bus Enable - This signal enables the SCSI bus drivers for -DB7 through -DBP. 


Target Group Select - Enables the SCSI bus drivers for I/-O, C/-D, -MSG, and —REQ. 


Initiator Group Select - Enables the SCSI bus drivers for -ACK and -ATN. 


Arbitration - Enables decode of IDO - lD2 and asserts priority decode as SCSI data bus 
ID. 


Identification - The ID signals are used during arbitration to select the correct DBx line. 


Input/Output - This line is used to drive or receive the SCSI signal I/-O. 


Control/Data - This line is used to drive or receive the SCSI signal C/-D. 


Message - This line is used to drive or receive the SCSI signal -MSG. 


Request - This line is used to drive or receive the SCSI signal -REQ. 


Acknowledge - This line controls the SCSI signal -ACK. 


Attention - This line controls the SCSI signal -ATN. 


Busy - This line indicates the received state of the SCSI signal —BSY. 


Busy - This line drives the SCSI signal —BSY. 


Select - This line indicates the received state of the SCSI signal -SEL. 
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SIGNAL DESCRIPTIONS 


Slgnal 
Pln 
Slgnal 
Name 
Number 
Descrlptlon 


SELOUT 
49 
Select - This line drives the SCSI signal -SEL. 


VL83C11 


RSTIN 
9 
Reset - This line indicates the received state of the SCSI signal -RST. 


_-RSTOUT 
47 
Reset - This line drives the SCSI signal -RST. 


VDD 
28 
+5 V 


GND 
2, 13, 17, 39, 43 Ground 


FUNCTIONAL DESCRIPTION 
The VL83C11 General Purpose 
Tranceiver has been designed primarily 
a buffer whose purpose is to translate 
signals from a microprocessor data bus 
to the low impedance, terminated, 48 
mA, single ended, environment of the 
SCSI bus. 


There is also an arbitration scheme, 
consistent with SCSI requirements, 
implemented in this device's logic. 


LOGICAL OPERATION 
Bus Operation - Data bus direction is 
usually controlled with a single line 
—DBEN (pin 35). With —DBEN active 
(low voltage level), data flow is from Dx 
to DBx or onto the SCSI data bus. 


APPLICATIONS 
Drlvlng Clrcultry 
The VL83C11 can be driven with either 
7400 TTL, LS or Schottky or a MOS 
microprocessor. 


A typical driver/load implementation is 
represented in Figure _2, TTL Drive of 
the VL83C11. 


Arbitration - Arbitration allows one SCSI 
device to gain control of the SCSI bus 
so that it can assume a role as Initiator 
or Target. Arbitration is a system 
option, but if not implemented, there 
can be only one Initiator. 


The SCSI ID bit is a single bit on the 
data bus which corresponds to the 
SCSI device's unique SCSI Address. 
All other seven data bus bits are 
released by the SCSI device. During 
arbitration, parity is not guaranteed, but 
may not be driven to the false state. 


During arbitration with the VL83C11, 
—DBEN is normally inactive and ARB is 
driven active (high voltage level). 


Output Loadlng 
Output loading of the VL83C11 is 
prescribed in ANSI document X3T9.2, 
SCSI, Small Computer Systems 
Interface, Section 4, Physical level. An 
example of a typical bus loading is 
shown in Figure 1, Illustration of SCSI 
Bus Loading. Note that the resistive 


FIGURE 1: ILLUSTRATION OF SCSI BUS LOADING 


VL83C11 


Under those circumstances, -DBP will 
be high as will all other -DBx lines 
except for the one showing a decode of 
the —lD2 - -IDO lines. 


Target Group Select (TGS) - When the 
TGS line is driven active (high voltage 
level), the driving device is controlling in 
the Target role. The purpose is to 
enable the VL83C11 SCSI drivers for 
signals I/-0, C/-D, -MSG, and —REQ. 


Initiator Group Select (IGS) - When at a 
high voltage level, the IGS line enables 
the SCSI bus drives for -ATN and 
-ACK that the driver is in the Initiator 
role. In the low voltage state, -ATN and 
-ACK will be received by the Initiator. 


loading element is clearly specified 
regarding terminating resistors. In 
contrast, the capacitive/inductive loads 
imposed as a result of cabling, connec- 
tors, or printed circuitry traces can only 
be estimated when the application has 
been defined. External loading must be 
considered when evaluating the AC 
characteristics. 


0 
0 


220 Q 
220.9 


aao Q 
I CL 
aao n 


V 
V 


LOADS 
LOADS 


Note: SCSI bus may be loaded per ANSI X3T9.2, Section 4. 
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FIGURE 2. TTL DRIVE OF VL83C11 


VL83C11 


748240 DRIVER 


VL83C11 


Note: 748240 easily drives eight VL83C11 driver chips. 
AC CHARACTERISTICS: TA = o=>c to +1o°c, vcc = s v 1 5% 
PRQPAG/.\T|0N DELAY 
Receiver chip, measurements are to be 
conforms to propagation delays 
Propagatbn [)e|ey Referenee defines 
made relative to other signals defined 
illustrated in Data Bus and Control 
measurement points used in determina- 
as references. 
Signal Turnaround, as well as Control 
tion of delay times. Since there is no 
CH"; -|-|M|NG 
359"?" and ATbI"aiI°" Deialf Times- 
Internal clock In the VL83C11 Dr|ver/ 
The VL83C11 Drive,/Receive, chip 


PROPAGATION DELAY REFERENCE 


Symbol 
Parameter 
Condltlon 


tPDHH 
No Internal Clock 


tPDLL 
No Internal Clock 


tPDHL 
No Internal Clock 


PROPAGATION DELAY REFERENCE TIMING 


INPUT 
2.0 V 


0.5 V 


OUTPUT 
tPDHH 


o.s v 


I 


2.0 V 


tPDLL 


2.0 V 
OUTPUT 
0.5 V 


IPDHL 
—>| 
tPDLH 
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DATA BUS PROPAGATION 
. 


-0-00-04-0-A 
OJ 
IO—* 


Symbol 
Parameter 
Condltlon 


Data Bus to SCSI Bus Delay 


SBEN True to Data Bus Three State 


SBEN False to SCSI Bus Release 


SCSI Bus to Data Bus Delay 


DATA BUS PROPAGATION TIMING 


—DBEN 


t2 


D0 — D7, DP 


t1 
—>I 
I3 
t4 


-DBO——DB7/, 
Iii 
-DBP 


TGS GATED CONTROL SIGNAL DELAYS 


Symbol 
Parameter 
Condltlon 


Control Slgnal Delay to SCSI Bus 


I-OPU 
l-F 
I-O(D\I 
O3 
U1 


\l 
U1\l 


TGS True to Input Release 


TGS False to SCSI Bus Release 


SCSI Bus Receiver Delay 


TGS GATED CONTROL SIGNAL DELAYS TIMING 


"res 


t6 
<- 


|/0, 0/0, MSG, REQ 


t5 
-pl 
:7 
t8 


I/-<>»<=/—v.-MSG.-REQ 
-—- 
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IGS GATED CONTROL SIGNAL DELAYS 


Symbol 


v-0--0--0--0 _L_;_.LgQI\J—-KC) 


NNOO 


Parameter 


Control Slgnal Delay to SCSI Bus 


IGS True to Input Release 


IGS False to SCSI Bus Release 


SCSI Bus Recelver Delay 


IGS GATED CONTROL SIGNAL DELAYS TIMING 


IGS 


ACK, ATN 


t9 
—§' 
t11 
I12 


-’*°*<'-AT“ 
_ 


CONTROL SIGNAL TURNAROUND 


Symbol 
Parameter 


I-0I-O-_L-L -b 
(.0 
C 


Recelver Delay BSY RST SEL 


Driver Delay BSY RST SEL 


CONTROL SIGNAL TURNAROUND TIMING 


BSYOUT, SELOUT, RSTOUT 


t14 


-BSY, -SEL, -RST 


I13 
113 


BSYIN, SELIN, RSTIN 


ARBITRATION DELAY 


I-OI 
I-OI -L 
_L O3 
U1 
I 
N 
NO 
O 


Symbol 
Parameter 


ARB True to -DBO 7 True 


ARB False to -DBO 7 False 


ARBRITRATION DELAY TIMING 


ARB 
4__ t15 


-DBO - -DB7 
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Condition 


Condltlon 
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ABSOLUTE MAXIMUM RATIINGS 


Ambient Operating 
Stresses above those listed may cause 
in this data sheet is not implied. 
Temperature 
0°C to +70°C 
permanent damage to the device. 
' 
Exposure to absolute maximum rating 


O 
O 
These are stress ratings only, functional 
conditions for extended periods may 
Storage Temperature 
65 C to +150 C 
operation of this device at these or any 
affect device reliability. 
Supply Voltage to 
other conditions above those indicated 
Ground Potential 
-0.5 V to +6.0 V 


Applied Input 
Voltage 
-0.5 V to VCC + 0.5 V 


Power Dissipation 
800 mW 


DC CHARACTERISTICS: TA = ooc to +7o°c, vcc = s v +_- 5% 


Symbol 
Parameter 
Condltlons 


VCC 
Positive Supply Voltage 
4.75 


ICC 
erating Current 
mA 
All Inputs = VIL = 0.8 


VIH 
High Level Input Voltage 


VIL 
Low Level Input Voltage 


IIH 
High Level Input Current (SCSI) 
VIH - 5.25 


IIL 
Low Level Input Current (SCSI) 
VIL = 0 


IIL 
ow Level Input Current (DP) 
mA 
VIL -= 0 


IIH 
High Level Input Current (All Other Pins) 
VIH = 5.25 


IIL 
Low Level Input Current (All Other Pins) 
VIL = 0 


VOH 
I h Level Output Voltage 
VCC = 4.75 V, IOH = 7.0 mA 


VOL 
Low Level Output Voltage 
VCC -= 4.75 V, IOL = 7.0 mA 


VOL~ 
Low Level Output Voltage (SCSI) 
VCC = 4.75 V, IOL - 48.0 mA 
IIEEEIHHHIIIB 
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FEATURES 
Two independent full-duplex 
channels 


0 to 1.5M bit/second 


Multi-protocxal operation for NRZ, 
NRZI, or FM 


Asynchronous mode includes 1, 1.5, 
or 2 stop bits per character 


Programmable clock factor 


Break generation and error detection 


Intelligent SDLC/HDLC 


Local loopback and auto echo 


N 
. 
VL8530 
SERIAL COMMUNICATIONS CONTROLLER (soc) 


DESCRIPTION 
The VL8530 Serial Communications 
Controller (SCC) is a dual-channel, 
multi-protocol data communications 
peripheral designed for use with 
conventional non-multiplexed buses. 
The SCCcan be software configured 
to satisfy a wide variety of serial 
communications applications. The 
device contains a variety of new, 
sophisticated internal functions, 
including on-chip baud rate genera- 
tors, digital phase-locked loops, and 
crystal oscillators that dramatically 
reduce the need for external logic. 
modes 


Synchronous support includes 
internal or external character 
synchronization 


D1 


D3 


D5 


D7 


INT 


IEO 


IE1 
HNTACK 


VCC 


—VW>REQA 
-SYNCA 
-RTXCA 
RXDA 
-TRXCA 
TXDA 


-DTR/—REOA 


—RTSA 


-—CTSA 


—DCDA 


PCLK 


VL8530 


1 
40 


2 
39 


3 
38 
4 
37 


5 
36 


6 
35 


7 
34 
8 
33 
9 
32 


10 
31 


1 1 
30 


1 2 
29 


1 3 
28 


1 4 
27 


1 5 
26 


1 6 
25 
17 
24 


18 
23 


19 
22 
20 
21 


oo 
02 
04 
oe 
-an 
awn 
IVB 
-cs 
uec 
sue 
-4M#REOB 
-svuce 
—RTXCB 
nxoe 
-TRXCB 
TXDB 
-orneneoe 
-arse 
-orse 
-ocoe 


BLOCK DIAGRAM 


{HIP 
4-WP 
CONTROL 


CPU 
BUS I/O 


INTERRUPT 
CONTROL 
LINES 


ORDER INFORMATION 


Part 
Clock 


INTERNAL 
CONTROL 
LOGIC 


BAUD RATE 
GENERATOR 
A 


CHANNEL A 
REGISTERS 


INTERNAL BUS 


INTERRUPT 
CONTROL 
LOGIC 


CHANNEL B 
REGISTERS 


BAUD RATE 
GENEIBIATOR 


The SCC handles asynchronous for- 
mats, synchronous byte-oriented pro- 
tocols, such as IBM Bisync, and syn- 
chronous bit-oriented protocols, such 
as HDLC and IBM SDLC. This ver- 
satile device supports virtually any 
serial data transfer application (cas- 
sette, diskette, tape drives, etc.). 


The device can generate and check 
CRC codes in any synchronous mode 
and can be programmed to check data 
integrity in various modes. The SCC 
also has facilities for modem controls 
in both channels. 


PIN DIAGRAM 


SERIAL DATA 
CHANNEL A 
CHANNEL CLOCKS 
<_> -svuc 
-WAIT!-REQUEST 


DISCRETE 
QQNTRQL 
<-- MODEMDMA, OR 
mo STATUS 
omER comnots 
A 
. 


DISCRETE 
CONTROL 
<_ MODEMDMA, oa 
mo STATUS 
omen CONTROLS 
e 


SERIAL DATA 
<;HANNgL e 
CHANNEL CLOCKS 
_sv~o 
-WAIT!-REOB 


J 


VL8530-04PC 
VL8530-04CC 
VL8530-O4OC 
VL8530-06PC 
VL8530-06CC 
VL8530 06OC 


Plastic DIP 
4 MHz 
Ceramic DIP 
Plastic Leaded Chi Carrier PLCC 
Plastic DIP 
6 MHz 
Ceramic DIP 
- 
Plastic Leaded Chi Carrier PLCC 
Note: Operating temperature range is 0° to +70°C. 
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PIN DIAGRAM 


I EO 


I El 


—lNTACK 


VCC 


—W/-REOA 


-SYNCA 


—RTXCA 


RXDA 


-TRXCA 


TXDA 


N.C. 


SIGNAL DESCRIPTIONS 


E] 
E 
IE 
III 
IE 
IE 
III 
IE 
E 
Ii 


Slgnal 
DIP Pln 
Slgnal 
Nam 
Number 
Descrlptlon 


A/-B 
34 
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51% 


—I 


Ei—3 E8 E—8 E9 H-8 [58 E-E [:58 H-éE32 


IEiEEEEI@EIE§ 


IJ 


N.C. 
-RTSA 
CDA—DCDB —RTSB 
N.C. 
-DTR/-REOA 
—CTSA 
PCLK -CTSB —DTRREQB 


write operation occurs. 


-OE 
33 


—CTSA, 
1 8, 
-CTSB 
22 


5;-1 A/-B 
-cs 


E1] 0/-c 


N.C. 
one 
-W/-REOB 


-SYNCB 


—RTXCB 


@11 nxoe 


go) -TRXCB 


TXDB 


VL8530 


Channel A/Channel B Select - This input signal selects the channel on which the read or 


Chip Enable - This active low input signal selects the SCC for a read or write operation. 


Clear To Send - Active low inputs - If these pins are programmed as auto enables, a low on 
the inputs enables the respective transmitters. If not programmed as auto enables, they may 
be used as general-purpose inputs. Both inputs are Schmitt trigger buffered to accommo- 
date slow rise time inputs. The SCC detects pulses on these inputs and can interrupt the 
CPU on both logic level transitions. 


D/—C - 
32 


—DCDA, 
19 
—DCDB 
21 


Data/Control Select - This input signal defines the type of information transferred to or from 
the SCC. A high means data is transferred; a low indicates a command. 


Data Carrier Detect - Active low inputs - These pins function as receiver enables if they are 
programmed for auto enables; otherwise, they may be used as general-purpose input pins. 
Both pins are Schmitt trigger buffered to accomodate slow rise time signals. The SCC 
detects pulses on these pins and can interrupt the CPU on both logic level transitions. 


DO-D7 
40,1 ,39,2,38, 
3,37,4 


-DTR/—REOA 
1 6. 
-DTR/-REOB 
24 
direct memeory access (DMA) controller. 


IEI 
7 


IEO 
6 


Data Bus - These bidirectional, three-state lines carry data and commands to and from the 
SCC. 


Data Terminal Ready/Request - These active low outputs follow the state programmed into 
the -DTR bit. They can also be used as general-purpose outputs or as request lines for a 


Interrupt Enable In - Active high output - IEI is used with IEO to form an interrupt daisy chain 
when there is more than one interrupt-driven device. A high IEI indicates that no other higher 
priority device has an interrupt underservice or is requesting an interrupt. 


Interrupt Enable Out - Active high output - IEO is high only if IEI is high and the CPU is not 
servicing an SCC interrupt or the SCC is not requesting an interrupt (Interrupt Acknowledge 
cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits 
interrupts from lower priority devices. 


-INT 
5 
requests an interrupt. 
Interrupt Request - Active low open-drain output - This signal is activated when theSCC 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
DIP Pln 
Name 
Number 
Slgnal 
Descrlptlon 


-INTACK 
8 


PCLK 
20 


-RD 
36 


RXDA, 
13, 
RXDB 
27 


—RTXCA, 
12, 
-RTXCB 
28 


-RTSA, 
1 7, 
—RTSB 
23 


-SYNCA, 
1 1, 
-SYNCB 
29 


TXDA, 
15, 
TXDB 
25 


-TRXCA, 
1 4, 
-TRXCB 
26 


-WR 
35 


-W/—REOA, 
1 0, 
-W/-REOB 
30 


Interrupt Acknowledge - Active low input - This signal indicates an active Interrupt Acknowl- 
edge cycle. During this cycle, the SCC interrupt daisy chain settles. When —RD be-comes 
active, the SCC places an interrupt vector on the data bus (if IEI is high). The -INTACK 
signal is latched by the rising edge of PCLK. 


Clock - This input is the master SCC clock used to synchronize internal signals. PCLK is a 
TTL level signal. 


Read - Active low input - This signal indicates a read operation and, when the SCC is se- 
lected, enables the SCC‘s bus drivers. During the Interrupt Acknowledge cycle, this signal 
gates the interrupt vector onto the bus if the SCC is the highest priority device requesting an 
interrupt. 


Receive Data - Active high inputs - These input signals receive serial data at standard TTL 
levels. 


Receive/Transmit Clocks - Active low inputs - These pins can be programmed in several 
different modes of operation. In each channel, -RTXC may supply the receive clock, the 
transmit clock, the clock for the baud rate generator, or the clock for the digital phase locked 
loop. These pins can also be programmed for use with the respective -SYNC pins as a 
ciystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in asynchro- 
nous modes. 


Request To Send - Active low outputs - When the —RTS bit in write register 5 (figure 7) is set, 
the —RTS signal goes low. When the -RTS bit is reset in the asynchronous mode and auto 
enable is on, the signal goes high afterthe transmitter is empty. In synchronous mode or in 
asynchronous mode with auto enable off, the —RTS pin strictly follows the state of the —RTS 
bit. Both pins can be used as general purpose outputs. 


Synchronization - Active low inputs or outputs - These pins can act either as inputs or outputs, 
or part of the ciystal oscillator circuit. In the asynchronous receive mode (crystal oscillator 
option not selected), these pins are inputs similar to —CTS and —DCD. In this mode, transi- 
tions on these lines affect the state of the synchronous/hunt status bits in read register 0 
(Figure 6) but have no other function. 


In external synchronization mode with the crystal oscillator not selected, these lines also act 
as inputs. In this mode, -SYNC must be driven low to receive clock cycles after the last bit in 
the synchronous character is received. Character assembly begins on the rising edge of the 
receive clock immediately preceding the activation of -SYNC. 


In the internal synchronization mode (Monosync and Bisync) with the crystal oscillator not 
selected, these pins act as outputs and are active only during the part of the receive clock 
cycle in which synchronous characters are recognized. The synchronous condi-tion is not 
latched, so these outputs are active each time a synchronization pattern is recognized 
(regardless of character boundaries). In SDLC mode, these pins act as outputs and are valid 
on receipt of a flag. 


Transmit Data - Active high outputs - These output signals transmit serial data at standard 
TTL levels. 
' 


Transmit/Receive Clocks - Active low inputs or outputs - These pins can be programmed in 
several different modes of operation. -TRXC may supply the receive clock or the transmit 
clock in the input mode or supply the output of the digital phase-locked loop, the crystal 
oscillator, the baud rate generator, or the transmit clock in the output mode. 


Write - Active low input - When the SCC is selected, this signal indicates a write operation. 
The coincidence of —RD and —WR is interpreted as a reset. 


Wait/Request - Open-drain outputs when programmed for a wait function, driven high or low 
when programmed for a Request function - These dual-purpose outputs may be programmed 
as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the SCC 
data rate. The reset state is Wait. 
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FUNCTIONAL 
DESCRIPTION 
The functional capabilities of the SCC 
can be described from two different 
points of view. As a data communi- 
cations device, it transmits and receives 
data in a wide variety of data communi- 
cations protocols. As a microprocessor 
peripheral, the SCC offers valuable 
features as vectored interrupts, polling, 
and simple handshake capability. 


DATA COMMUNICATIONS 
CAPABILITY 
The SCC provides two independent full- 
duplex channels programmable for use 
in any common asynchronous or syn- 
chronous data communication protocol. 
Figure 1 and the following description 
briefly detail these protocols. 


Asynchronous modes - Transmission 
and reception can be accomplished 
independently on each channel with 5 
to 8 bits per character, plus optional 
even or odd parity. The transmitters 
can supply 1, 1 1/2, or 2 stop bits per 
character and a break output at any 
time. The receiver break-detection logic 
interrupts the CPU both at the start and 
at the end of a received break. 
Reception is protected from spikes by a 
transient spike-rejection mechanism 
that checks the signal one-half a bit 
time after a low level is detected on the 
receive data input (RXDA or RXDB). If 
the low does not persist (as in the case 
of a transient), the character assembly 
process does not start. 


Framing errors and overrun errors are 
detected and buffered together with the 
partial character on which they occur. 
Vectored interrupts allow fast servicing 
or error conditions using dedicated 
routines. Furthermore, a built-in 
checking process avoids the interpreta- 
tion of a framing error as a new start bit: 
a framing error results in the addition of 
one-half a bit time to the point at which 
the search for the next start bit begins. 


The SCC does not require symmetric 
transmit and receive clock signals 
a feature allowing use of the wide vari- 
ety of clock sources. The transmitter 
and receiver can handle data at a rate 
of 1, 1/16, 1/32, or 1/64 of the clock rate 
supplied to the receive and transmit 
clock inputs. In asynchronous modes, 
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the -SYNC pin may be pro-grammed as 
an input used for such functions as 
monitoring a ring indicator. 


Synchronous modes. The SCC 
supports both byte-oriented and bit- 
oriented synchronous communication. 
Synchronous byte-oriented protocols 
can be handled in several modes, al- 
lowing character synchronization with a 
6-bit or 8-bit synchronous character 
(Monosync) any 12-bit synchroni-zation 
pattern (Bisync), or with an external 
synchronous signal. Leading sync 
characters can be removed without 
interrupting the CPU. 


5- or 7-bit synchronous characters are 
detected with 8- or 16-bit patterns in the 
SCC by overlapping the larger pattern 
across multple incoming synchronous 
characters. 


The CRC checking for synchronous 
byte-oriented modes is delayed by one 
character time so that the CPU may 
disable CRC checking on specific 
characters. This allows the imple- 
mentation of IBM Bisync. protocxals. 


Both CRC-16 (X16 + X15 +X2 + 1) and 
CCITT (X16 + X12 + X5+ 1) error check- 
ing polynomials are supported. Either 
polynomial may be selected in all 
Synchronous modes. Users may preset 
the CRC generator and checker to all 
ones or all zeros. The SCC also pro- 
vides a feature that automatically 
transmits CRC data when no other data 
is available for transmission. This 
allows for high-speed transmissions 
under DMA control, with no need for 
CPU intervention at the end of a mes- 
sage. When there is no data or CRC to 
send in synchronous modes, the 
transmitter inserts 6-, 8-, or 16-bit 
synchronous characters, regardless of 
the programmed character length. 


The SCC supports synchronous bit- 
oriented protocols, such as SDLC and 
HDLC, by performing automatic flag 
sending, zero insertion, and CRC gen- 
eration. A special command can be 
used to abort a frame in transmission. 
At the end of a message, the SCC 
automatically transmits the CRC and 
trailing flag when the transmitter un- 
derruns. The transmitter may also be 
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programmed to send an idle line con- 
sisting of continuous flag characters or 
a steady marking condition. 


If a transmit underrun occurs in the 
middle of a message, an external/sta- 
tus interrupt warns the CPU of this 
status change so that an abort may 
be 
issued. The SCC may also be pro- 
grammed to send an abort itself in case 
of an underrun, relieving the CPU of this 
task. One to eight bits per character 
can be sent, allowing recep-tion of a 
message with no prior infor-mation 
about the character structure in the 
information field of a frame. 


The receiver automatically acquires 
synchronization on the leading flag of a 
frame in SDLC or HDLC and provides a 
synchronization signal on the -SYNC 
pin (an interrupt can also be pro- 
grammed). The receiver can be 
programmed to search for frames 
addressed by a single byte (or four bits 
within a byte) of a user-selected 
address or to a global broadcast 
address. In this mode, frames not 
matching either the user-selected or 
broadcast address are ignored. The 
number of address bytes can be 
extended under software control. For 
receiving data, an interrupt on the first 
received character, or an interrupt on 
every character, or on special con-dition 
only (end-of-frame) can be selected. 
The receiver automatically deletes all 
zeros inserted by the transmitter during 
character assembly. The CRC is also 
calculated and is automatically checked 
to validate frame transmission. At the 
end of transmission, the status of a 
received frame is availabe in the status 
registers. In SDLC mode, the SCC 
must be programmed to use the SDLC 
CRC polynomial, but the generator and 
checker may be preset to all ones or all 
zeros. 


The CRC is inverted before transmis- 
sion and the receiver checks against 
the bit pattern 0001110100001111. 


The NRZ, NRZI, or FM cxading may be 
used in any 1x mode. The parity 
options available in asynchronous 
modes are available in synchronous 
modes. 
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The SCC can be conveniently used 
interrupt the CPU when the first 
transfer the message to memory. The 
under DMA control to provide high- 
character of a messa e is received 
SCC then issues an end-of-frame 
g 
. 
speed reception or transmission. In 
The CPU then enables the DMA to 
interrupt and the CPU can check the 
reception, for example, the SCC can 
status of the received messsage. 


FIGURE 1. SCC PROTOCOLS 
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The CPU is thereby freed for other 
service while the message is being 
received. The CPU may also enable 
the DMA first and have the SCC in- 
terrupt only on end-of-frame. This 
procedure allows all data to be trans- 
ferred via the DMA. 


SDLC LOOP MODE 
The SCC supports SDLC loop mode in 
addition to normal SDLC. In an SDLC 
loop, there is a primary controller 
station that manages the message 
traffic flow on the loop and any number 
of secondary stations. In SDLC loop 
mode, the SCC performs the functions 
of a secondary station while an SCC 
operating in regular SDLC mode can 
act as a controller (Figure 3). 


A secondary station in an SDLC Loop 
is always listening to the messages 
being sent around the loop, and in fact 
must pass these messages to the rest 
of the loop by retransmitting them with 
a one-bit time delay. The secondary 
station can place its own message on 
the loop only at specific times. The 
controller signals that secondary sta- 
tions may transmit messages by 
sending a special character, called an 
End Of Poll (EOP), around the loop. 
The EOP character is the bit pattern 
11111110. Because of zero insertion 
during messages, this bit pattern is 
unique and easily recxagnized. 


When a secondary station has a mes- 
sage to transmit and recognizes an 
EOP on the line, it changes the last 
binary 1 of the EOP to a 0 before 
trans-mission. This has the effect of 
turning the EOP into a flag sequence. 
The secondary station now places its 
message on the loop and terminates 
the message with an EOP. Any sec- 
ondary stations, further down the loop 
with messages to transmit, can then 
append their messages to the 
message of the first secondary station 
without messages to send. The 
following stations merely echo the 
inwming messages and are prohib- 
ited from placing messages on the 
loop (except upon recognizing an 
EOP). The SDLC loop mode is a 
programmable option in the SCC; 
NRZ, NRZI, and FM coding may all be 
used in SDLC Loop mode. 


BAUD RATE GENERATOR 
Each channel in the ESCC contains a 
programmable baud rate generator. 
Each generator consists of two 8-bit 
time constant registers that form a 16- 
bit time-constant, a 16-bit down 
counter, and a flip-flop on the output 
producing a square wave. On startup, 
the flip-flop on the output is set in a 
HIGH state, the value in the time- 
constant register is loaded into the 
counter, and the counter starts count- 
ing down. The output of the baud rate 
generator toggles upon reaching 0, 
the value in the time-constant register 


process is repeated. The time constant 
may be changed at any time, but the 
new value does not take effect until the 
next load of the counter. 


The output of the baud rate generator 
may be used as either the transmit 
clock, the receive clock, or both. It can 
also drive the digital phase-locked loop 
(see next section). 


If the receive clock or transmit clock is 
not programmed to come from the 
-TRxC pin, the output of the baud rate 
generator may be echoed out via the 
-TRxC pin. 


The following formula relates the time 
constant to the baud rate (the baud rate 
is in bits/second and BR clock period is 
in seconds): 
baud rate = 


1 


2 (time constant+2) x (BR clock period) 


DIGITAL PHASE-LOCKED LOOP 
The ESCC contains a digital phase- 
locked-Ioop (DPLL) to recover clock 
information from a data stream with 
NRZI or FM encoding. The DPLL is 
driven by a clock that is nominally 32 
(NRZI) or 16 (FM) times the data rate. 
The DPLL uses this clock, along with 
the data stream, to construct a clock 
for the data. This clock may then be 
used as the SCC receive clock, the 
transmit clock, or both. 


FIGURE 2. DETECTING 5- OR 7-BIT 
FIGURE 3. AN SDLC LOOP 
SYNCHRONOUS CHARACTERS 
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For NRZI encoding, the DPLL counts 
the 32x clock to create nominal bit 
times. As the 32x clock is counted, the 
DPLL is searching the incoming data 
stream for edges (either 1 to 0 or 0 to 
1). Whenever an edge is de-tected, the 
DPLL makes a count adjustment (during 
the next counting cycle), producing a 
terminal count closer to the center of the 
bit cell. 


For FM encoding, the DPLL still counts 
from 0 to 31, but with a cycle corres- 
ponding to two bit times. When the 
DPLL is locked, the clock edges in the 
data stream should occur between 
counts 15 and 16, and between counts 
31 and 0. The DPLL looks for edges 
only during a time centered on the 15 to 
16 counting transition. 


The 32x clock for the DPLL can be 
programmed to come from either the 
-RTxC input or the output of the baud 
rate generator. The DPLL output may 
be programmed to be echoed out of the 
ESCC via the -TRxC pin (if this pin is 
not being used as an input). 


DATA ENCODING 
The ESCC may be programmed to en- 
code and decode the serial data in four 
different ways (Figure 4). In NR2 en- 
coding, a 1 is represented by a HIGH 
level and a 0 is represented by a LOW 
level. In NRZI encoding, a 1 is repre- 
sented by no change in level and a 0 is 
represented by a change in level. 


In FM1 (more properly, bi-phase mark), 
a transition occurs at the beginning of 
every bit cell. A 1 is represented by 


an additional transition at the center of 
the bit cell and a 0 is represented by no 
additional transition at the center of the 
bit cell. In FMO (bi-phase space), a 
transition occurs at the beginning of 
every bit cell. 'A 0 is represented by an 
additional transition at the center of the 
bit cell, and a 1 is represented by no 
additional transition at the center of the 


bit cell. 


In addition to these four methods, the 
ESCC can be used to decode Manch- 
ester (bi-phase level) data by using the 
DPLL in the FM mode and program- 
ming the receiver for NRZ data. 
Manchester encoding always produces 
a transition at the center of the bit cell. 
If the transition is 0 to 1, the bit is a 0. If 
the transition is 1 to 0, the bit is a 1. 


AUTO ECHO AND LOCAL 
LOOPBACK 
The ESCC is capable of automatically 
echoing everything it receives. This 
feature is useful mainly in Asyn- 
chronous modes, but works in Syn- 
chronous and SDLC modes as well. In 
Auto Echo mode, TxD is RxD. Auto 
Echo mode can be used with NRZI or 
FM encoding with no additional delay, 
because the data stream is not de- 
coded before retransmission. ln Auto 
Echo mode, the -CTS input is ignored 
as a transmitter enable (although transi- 
tions on this input can still cause 
interrupts if programmed to do so). In 
this mode, the transmitter is actually 
bypassed and the pro-grammer is 
responsible for disabling transmitter 
interrupts and Wait/Request on trans- 
mit. 


The ESCC is also capable of local 
loopback. In this mode TxD is RxD, just 
as in auto echo mode. However, in 
local loopback mode, the internal 
transmit data is tied to the internal 
receive data and RxD is ignored (except 
to be echoed out via TxD). The —CTS 
and —DCD inputs are also ig-nored as 
transmit and receive enables. How- 
ever, transitions on these inputs can still 
cause interrupts. Local loopback works 
in asynchronous, synchronous, and 
SDLC modes with NRZ, NRZI, or FM 
coding of the data stream. 


I/O INTERFACE CAPABILITIES 
The ESCC offers the choice of polling, 
interrupt (vectored or nonvectored), and 
block transfer modes to transfer data, 
status, and control information to and 
from the CPU. The block transfer mode 
can be implemented under CPU or 
DMA control. 


POLLING 
All interrupts are disabled. Three status 
registers in the ESCC are auto-matically 
updated whenever any function is 
performed . For example, end-of-frame 
in SDLC mode sets a bit in one of these 
status registers. The idea behind 
polling is for the CPU to periodically 
read a status register until the register 
contents indicate the need for data to 
be transferred. Only one register needs 
to be read; depending on its contents, 
the CPU either writes data, reads data, 
or continues. Two bits in the register 
indicate the need for data transfer. 


FIGURE 4. DATA ENCODING METHODS 
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An alternative is a poll of the Interrupt 
Pending register to determine the 
source of an interrupt. The status for 
both channels resides in one register. 


INTERRUPTS 
When an SCC responds to an Interrupt 
Acknowledge signal (-INTACK) from the 
CPU, an interrupt vector may be placed 
on the data bus. This vector is written in 
Write Register 2 (WR2) and may be 
read in Read Register 2A (RR2A) or 
Read Register 2B (RR2B) (Figures 8). 


To speed interrupt response time, the 
SCC can modify three bits in this vector 
to indicate status. If the vector is read in 
Channel A, status is never included; if it 
is read in Channel B, status is always 
included. 


Each of the six sources of interrupts in 
the SCC (Transmit, Receive, and 
External/Status interrupts in both 
channels) has three bits associated with 
the interrupt source: Interrupt Pending 
(IP), Interrupt Under Service (IUS), and 
Interrupt Enable (IE). Operation of the 
IE bit is straightforward. If the IE bitis 
set for a given interrupt source, that 
source can request interrupts. The 
exception is when the MIE (Master 
Interrupt Enable) bit in WR9 is reset and 
no interrupts may be requested. The IE 
bits are write only. 


The other two bits are related to the 
interrupt priority chain (Figure 5). As a 
microprocessor peripheral, the SCC 
may request an interrupt only when no 
higher priority device is requesting one; 
e.g., when IEI is high. If the device in 
question requests an interrupt, it pulls 


down -INT. The CPU then responds 
with -INTACK, and the interrupting 
device places the vector on the data 
bus. 


In the SCC, the IP bit signals a need for 
interrupt servicing. When an IP bit is 1 
and the IEI input is high, the INT output 
is pulled low, requesting an interrupt. 
In the SCC, if the IE bit is not set by 
enabling interrupts, then the IP for that 
source can never be set. The IP bits 
are readable in RR3A. 


The IUS bits signal that an interrupt 
request is being serviced. If an IUS is 
set, all interrupt sources of lower 
priority in the SCC and external to the 
SCC are prevented from requesting 
interrupts. The internal interrupt 
sources are inhibited by the state of the 
internal daisy chain, while lower priority 
devices are inhibited by the IEO output 
of the SCC being pulled LOW and 
propagated to subsequent peripherals. 
An IUS bit is set during an interrupt ac- 
knowledge cycle if there are no higher 
priority devices requesting interrupts. 


There are three types of interrupts: 
transmit, receive, and external/status. 
Each interrupt type is enabled under 
program control with Channel A having 
higher priority than Channel B, and with 
receive, transmit, and external/status 
interrupts prioritized in that order within 
each channel. When the transmit 
interrupt is enabled, the CPU is inter- 
rupted when the transmit buffer be- 
comes empty. (This implies that the 
transmitter must have had a data 
character written into it so that it can 
become empty.) When enabled, the 


receiver can interrupt the CPU in one of 
three ways: 


° 
On first receive character or special 
receive condition 


' 
On all receive characters or special 
receive condition 


° 
On special receive condition only. 


Interrupt on first character or special 
condition and interrupt on special 
condition only are typically used with 
the Block Transfer mode. A special 
receive condition is one of the following: 
receiver overrun, framing error in 
Asynchronous mode, end-of-frame in 
SDLC mode, and optionally, a parity 
error. The special receive condition 
interrupt is different from an ordinary 
receive character interrupt only in that 
the status is placed in the vector during 
the Interrupt Acknowledge cycle. In 
interrupt on first receive character, an 
interrupt can ocx:ur from special receive 
conditions any time after the first receive 
character interrupt. 


The main function of the externall 
status interrupt is to monitor the signal 
transitions of the —CTS,—CCD, and 
-SYNC pins; however, an externall 
status interrupt is also caused by a 
transmit underrun condition, or a zero 
count in the baud rate generator, or by 
the detection of a break (asynchronous 
mode), abort (SDLC mode) or EOP 
(SDLC loop mode) sequence in the data 
stream. 


FIGURE 5. INTERRUPT SCHEDULE 
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The interrupt caused by the abort or 
EOP has a special feature allowing the 
SCC to interrupt when the abort or EOP 
sequence is detected or terminated. 
This feature facilitates the proper 
termination of the current message, 
correct initialization of the next mes- 
sage, and the accurate timing of the 
Abort condition in external logic in SDLC 
mode. In SDLC Loop mode, this feature 
allows secondary stations to recognize 
the need of the primary station to regain 


control of the loop during a poll se- 
quence. 


CPU/DMA BLOCK TRANSFER 
The SCC provides a Block Transfer 
mode to accommodate CPU block 
transfer functions and DMA controllers. 
The Block Transfer mode uses the Waitl 
Request output in conjunction with the 
Wait/Request bits in WR1. The Waitl 
Request output c_an be defined under 
software control as a Wait line in the 


CPU Block Transfer mode or as a 
Request line in the DMA Block Transfer 
mode. 


To a DMA controller, the SCC Request 
output indicates that the SCC is ready to 
transfer data to or from memory. To the 
CPU, the Wait line indicates that the 
SCC is not ready to transfer data, 
thereby requesting that the CPU extend 
the I/O cycle. The DTR/Request line 
allows full-duplex operation under DMA 
control. 


PROGRAMMING 
The SCC contains 13 write registers in 
each channel that are programmed by 
the system separately to configure the 
functional personality of the channels. 


In the SCC, register addressing is direct 
for the data registers only, which are 
selected by a high on the D/-C pin. In 
all other cases (with the exception of 
WRO and RRO), programming the write 
registers requires two write operations 
and reading the read registers requires 
both a write and a read operation. The 
first write is to WRO and contains three 
bits that point to the selected register. 
The second write is the actual control 
word for the selected register, and if the 
second operation is read, the selected 
read register is accessed. All of the 
registers in the SCC, including the data 
registers, may be accessed in this 
fashion. The pointer bits are auto- 
matically cleared after the read or write 
operation so that WRO ( or RRO) is 
addressed again. 


The system program first issues a series 
of commands to initialize the basic mode 
of operation. This is followed by other 
commands to qualify conditions within 
the selected mode. For example, the 
asynchronous mode, character length, 
clock rate, number of stop bits, and even 
or odd parity might be set first. Then the 
interrupt mode would be set, and, finally, 
receiver or trans-mitter enable. 


READ REGISTERS 
The SCC contains ten read registers 
(eleven counting receive buffer RR8) in 
each channel. Four of these may be 
read to obtain status information (RRO, 
RR1, RR10, and RR15). Two registers 
(RR12 and RR13) may be read to learn 
the baud rate generator time constant. 
The RR2 contains either the unmodified 
interrupt vector (Channel A) or the 
vector modified by status information 
(Channel B). Both RR7 and RR6 read 
the DMA FIFO. The RR3 contains the 
Interrupt Pending (IP) bits (Channel A). 


Figures 6 through 13 and Figure 31 
show the formats for each read register. 


The status bits of RRO and RR1 are 
carefully grouped to simplify status 
monitoring; 
e.g., when the interrupt 
vector indicates a special receive 
condition interrupt, all the appropriate 
error bits can be read from a single 
register (RR1). 


WRITE REGISTERS 
The SCC contains 13 write registers (14 
counting WR8, the transmit buffer) in 
each channel. These write registers are 
programmed separately to configure the 
functional personality of the channels. 
In addition, there are two registers (WR2 
and WR9) shared by the two channels 
that may be accessed through either of 
them; WR2 contains the interrupt vector 
for both channels, while WR9 contains 
the interrupt control bits. Figures 14 
through 28 and Figure 31 show the 
format of each write register. 


TIMING 
The SCC generates internal control 
signals from —WR and —RD that are 
related to PCLK. Since PCLK has no 
phase relationship with -WR and —RD, 
the circuitry generating these internal 
control signals must provide time for 
metastable conditions to disappear. 
This gives rise to a recovery time related 
to PCLK. The recovery time applies 
only between bus transactions involving 
the SCC. The recovery time required for 
proper operation is specified from the 
rising edge of —WR or -RD in the first 
transaction involving the SCC, to the 
falling edge of WR or RD in the second 
transaction involving the SCC. This time 


must be at least four PCLK cycles plus 
200 ns. 


READ CYCLE TIMING 
Figure 32 illustrates Read cycle timing. 
Addresses on A/-B and D/-C and the 
status on -INTACK must remain stable 
through the cycle. If —CE falls after -RD 
falls or if it rises before —RD rises, the 
effective —RD is shortened. 


WRITE CYCLE TIMING 
Figure 33 illustrates Write cycle timing. 
Addresses on A/-B and D/—C and the 
status on -INTACK must remain stable 
throughout the cycle. If —CE falls after 
-WR falls, or if it rises before -WR rises, 
the effective -WR is shortened. 


INTERRUPT ACKNOWLEDGE CYCLE 
TIMING 
Figure 34 illustrates Interrupt Acknowl- 
edge cycle timing. Between the time 
-INTACK goes low and the falling edge 
of -RD, the internal and external IEI/IEO 
daisy chains settle. 
If there is an 
interrupt pending in the SCC and IEI is 
high when -RD falls, the Acknowledge 
cycle is intended for the SCC. 
In this 
case, the SCC may be programmed to 
respond to —RD low by placing its 
interrupt vector on D0-D7 and it then 
internally sets the appropriate Interrupt- 
Under-Service latch. 
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FIGURE 9. READ REGISTER 3 
FIGURE 13. READ REGISTER 15 
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POINT HIGH 
REE} QETEQESTRTIQIIZIERRUPTS 
FIGURE 1a. WRITE REGISTER 4 
ENABLE INT 0N NEXT RX CHARACTER 
5% 2S‘.f'.€i=.ii‘é’;.ii‘-’E"°‘“° 
IT-IIEEEIIEEIEZIEEI 
||[|[| RESETHIGHESTIUS 
|__ FARM ENABLE 
HE] NULLCODE 
PAH“, 
u RESET Rx cRc CHECKER 
EVEN/_oDD 
|||g| REsET TX cRc GENERATOR 
|||,| RESET Tx UNDERRUN/EOM LATCH 
SYNC MODES ENABLE 
1 STOP BIT/CHARACTER 
' Wm P°'NT “'6” °°M'”“‘N° 
1 1/2 STOP BITS/CHARACTER 
2 STOP BITS/CHARACTER 
Em 
a BIT smc CHARACATER 
FIGURE15. wRiTE REGISTER1 
g ggiggggg §,'ff{",§‘,’§$,‘,“J,G, 
[1EXTERNAL svuc MODE 


| L ->-»---M 
iiil zzizsisziisz 
Tx INT ENABLE 
III] xe-1 CLOCK MODE 


PARITY IS SPECIAL CONDITION 
Eli Rx INT DISABLE 
Ell Rx INT ow FIRST CHARACTER oR SPCL. CONDITION 
3% I'I“>ii‘i1-I$hLsFi='E‘§IJLR<?<‘§§§I‘rio‘iiR§’~Pt<§iL'°°“°'T'°“ 
FIGURE 19. WRITE REGISTER s 
WAIT/DMA REQUEST on RECEIVE/-TRANS. 
-WAITIDMA REQUEST 
FUNCTION 
‘ 
| 
L 
WAIT/DMA REQUEST ENABLE 
-[X CRQ ENABLE 


RTS 
-SDLC/CRC - 16 


TX ENABLE 


IE=IIEI-IIEIIEEIIEEEIIEI 
N 
Eli] TX s BITS (OR LESS)/CHARACTER 
L. V0 
[ill TX 7 BITS/CHARACTER 
ETX e BITS/CHARACTER 
V‘ 
[1]] TX a BITS/CHARACTER 
"2 
DTR 


FIGURE 16. WRITE REGISTER 2 


V3 
INTERRU PT 
V4 
VECTOR 


V5 
_ 


V6 


V7 
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N 


SYNC7 
SYNC1 
SYNC7 
SYNC3 
ADR7 
ADR7 


SYNC7 
SYNC6 
SYNC5 
SYNC4 
SYNC15 
SYNC14 
SYNC11 
SYNC1O 


SYNC6 
SYNCO 
SYNC6 
SYNC2 
ADR6 
ADR6 


0 
1 


FIGURE 20. WRITE REGISTER 6 
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MEEMEEMM 


SYNC5 
SYNC5 
SYNC5 
SYNC1 
ADR5 
ADR5 


FIGURE 21. WRITE REGISTER 7 


SYNC4 
SYNC4 
SYNC4 
SYNCO 
ADR4 
ADR4 


SYNC3 
SYNC3 
SYNC3 


1 
ADR3 
X 


SYNC2 
SYNC2 
SYNC2 


1 
ADR2 
X 


HEEHHEWW 


SYNC5 
SYNC3 
SYNC13 
SYNC9 


1 


SYNC4 
SYNC2 
SYNC12 
SYNC8 


1 


SYNC3 
SYNC1 
SYNC11 
SYNC7 


1 


SYNC1 
SYNC1 
SYNC1 


1 
ADR1 
X 


SYNC2 
SYNC1 
X 
SYNCO 
SYNC10 
SYNC9 
$YNC6 
SYNC5 


1 
1 


SYNCO 
SYNCO 
SYNCO 


1 
ADRO 
X 


SYNCO 
x 
SYNC8 
SYNC4 
o 
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MONOSYNC, s BITS 
MONOSYNC, e BITS 
BISYNC, 16 BITS 
BISYNC, 12 BITS 
SDLC 
SDLC 
(ADDRESS RANGE) 


MONOSYNCJBBWS 
MONOSYNC, 6 BITS 
BISYNC, 16 BITS 
BISYNC, 12 BITS 
SDLC 
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FIGURE 22. WRITE REGISTER 9 
FIGURE 25. WRITE REGISTER 12 
IEHEWEIEHNM 
IEEIEEIEIIIEEIEIEIIE 


‘ E vis 
‘ 
‘ 
| E Tc, 


TCS 
LOWER BYTE OF 
STATUS HIGH/—STATUS LOW 
T04 
TIME CONSTANT 


O 
TC5 


' 
TC6 
NO RESET 
CHANNEL RESET B 
T97 
CHANNEL RESET A 
FORCE HARDWARE REsEr 
FIGURE 26. WRITE REGISTER 13 
EEWWEWW 


FIGURE 23. WRITE REGISTER 10 
_ 
I- 
TC8 
EEHIEEIEEIEII 
I— 1;; 
I_ 
s BIT/-8 BIT SYNC 
TO“ 
UPPER BYTE OF 
LOOP MOOE 
Te, 2 
TIME CONSTANT 
ABORT/—FLAG ON UNDERRUN 


MARK/—FLAG IDLE 
TC13 


TC14 
GO ACTIVE ON POLL 
TC15 


lillil 
NRZ 
Ell 
NRzi 
IIE 
FM1 (TRANSITION =1) 
FIGURE 27. WRITE REGISTER 14 
Ill] 
FMO (TRANSITION = 0) 
EEEEEIEIEHEIIIEII 
cRc RREsET v-o 
L 
‘ 
I 
BR GENERATOR ENABLE 


BR GENERATOR SOURCE 


FIGURE 24. WRITE REGISTER 11 
-DTR/REQUEST FUNCTION 


AUTO ECHO 
IEEEIEZIEIEEIEIIIEII 
LOCAL LOOPBACK 


-TRXC OUT =- XTAL OUTPUT 
NULL COMMAND 
—-TRXC OUT = TRANSMIT CLOCK 
ENTER SEARCH MODE 
-TRXC OUT = BR GENERATOR OUTPUT 
RESET MISSING CLOCK 
-TRXC OUT = DPLL OUTPUT 
II DISABLE DPLL 
Eli] SET SOURCE = BR GENERATOR 
-TRXC O/-I 
[IE SET SOURCE = -RTXC 
nu SET FM MODE 
Eli 
TRANSMIT CLOCK = -RTXC PIN 
nun SET NR2‘ MODE 
Ell 
TRANSMIT CLOCK = -TRXC PIN 
[IE TRANSMIT CLOCK = BR GEN. OUTPUT 
FIGURE 28. WRITE REGISTER 1 5 


lil RECEIVE CLOCK =. -RTXC PIN 


[1]] 
TRANSMIT CLOCK = DPLL OUTPUT 
EIIEEEIIEHEHEIIEII 
I RECEIVE CLOCK = -TRXC PIN 
| 
I 
L ° 


o 
HE RECEIVE CLOCK = BR GEN. OUTPUT 
ZERO COUNT IE 
IIREcEivE CLOCK = DPLL OUTPUT 


-RTXC XTAU-NO XTAL 
OCO ‘E 
SYNC/HUNT IE 


CTS IE 


TX UNDERRUN/EOM IE 


BREAK/ABORT IE 
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FIGURE 29. READ CYCLE TIMING 
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—CE 
> 
i 


D0-D7 
DATA VALIDI 
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FIGURE 30. WRITE CYCLE TIMING 
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‘ 
< 
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I: 
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/ 


D0-D7 
DATA VALID 


FIGURE 31. INTERRUPT ACKNOWLEDGE CYCLE TIMING 
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FIGURE 32. READ AND WRITE TIMING (SEE TABLE 1) 
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‘E 
‘B 
-INTACK 
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@ 5-—1<!E I 
gijn 
@ 
£9 
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»‘3¢°§?FE 
IQCI-——1> 
Eulil-‘ 
@ 
-W/-REQ 
H 


WAIT 
E @ 1 
- 
-W/-REQ 
I 
nsouesr 
@ 
@ 


-om/-REQ 
- 
GI I 
REQUEST 
@ 


—INT 
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FIGURE 33. RESET TIMING (SEE TABLE 1) 
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FIGURE 34. CYCLE TIMING (SEE TABLE 1) 
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TABLE 1. READ AND WRITE TIMING CHARACTERISTICS: TA =o=>c TO +1o=c 


No. Symbol 
Parameter 


O7 
U1-Q 
(DI\J 


44444434 


U1 
CDC) 


wPCl 
PCLK Low W|oth 
105 
TwPCh 
PCLK H1 h W|dth 
105 
200 
C 
PCLK Fall T|me 
10 
C 
PCLK R|se Tlme 
15 
C 
PCLK C cle Tlme 
250 
400 
2000 
A WR 
Address to -WR Setu Tlme 
A WR 
Address to -WR Hold T|me 
A RD 
Address to —RD Setu T|me 
9 
A RD 
Address to —RD Hold Tlme 
10 
TsIA PC 
-INTACK to PCLK Setu Tlme 
11 
TsIA| WR 
-INTACK to -WR Setu Tlme 
200 
12 
ThlA WR 
-INTACK to -WR Hold T|me 
13 
TsIA| RD 
-INTACK to -RD Setu Tlme 
14 
ThlA RD 
-INTACK to -RD Hold Tlme 
15 
ThIA PC 
-INTACK to PCLK Hold Tlme 
100 
16 
TsCE1 WR 
-CE Low to -WR Setu Tlme 
17 
ThCE WR 
—CE to -WR Hold Tlme 
18 
TsCEh WR 
-CE Hlh to -WR Setu Tlme 
100 
19 
TsCE1 RD 
—CE Low to -RD Setu Tlme 
20 
ThCE RD 
-CE to -RD Hold Tlme 
21 
TsCEh RD 
-CE H|h to —RD Setu T|me 
100 
22 
TwRD1 
-RD Low W|dth 
390 
23 
TdRD DRA 
-RD to Read Data ACIW8 Dela 
24 
TdRDr DR 
-RD to Read Data Not Val|d Dela 
25 
TdRDl DR 
-RD to Read Data Valld Dela 
25 
180 
26 
TdRD DRz 
-RD to Read Data Float Dela 
7 
45 
27 
TdA(DR) 
Address Requlred Val|d to 


é 
100 


@\| 


|\)-5-5U'I\I\| 
O3 
O7 C)@ 
@Q 
@ 


CDC) 


I'\) U1 O 


45>I\J O 
Read Data Val|d Dela 
28 
TwWR1 
-WR Low W|dth 
390 
29 
TsDW WR 
Wrlte Data to -WR Setu Tlme 
30 
ThDW WR 
Wr|te Data to —WR Hold Tlme 
31 
TdWR W 
-WR to Walt Val|d Dela 
20 
32 
TdRD W 
—RD to Wart V8||d Dela 
33 
TdWRl REQ 
—WR to -W/-REQ Not Valld Dela 
34 
TdRDf REQ 
—RD to -W/-REQ Not Valld Dela 
35 
TdWRr(REQ) 
—WR to -DTR/-REQ Not Valld Delay 


Q 


f\ 
/% 


200 
240 
TcPC 
TcPC 
+300 
+250 
36 
TdRDr(REQ) 
-RD to -DTR/—REQ Not Val|d Delay 
5TcPC 
5TcPC 
+300 
+250 
37 
TdPC INT 
PCLK to —lNT \/8|ld Dela 
38 
TdlA| RD 
-INTACK to —RD Acknowlede Dela 
250 
39 
TwRDA 
-RD Acknowlede W|dth 
40 
TdRDA DR 
-RD Ack 
to Read Data Valld Dela 
41 
TsIEl RDA 
IEI to -RD Acknowlede Setu Tlme 
42 
ThIE| RDA 
|Elto -RD Acknowlede Hold Tll'Tl8 
43 
TdlEI IEO 
IEI to IEO Dela T|me 
12 
44 
TdPC IEO 
PCLK to IEO Dela 
25 
45 
TdRDA INT 
—RD to -INT |nact|ve Dela 
46 
TdRD WRQ 
--RD to -WR Dela for No Reset 
47 
TdWRQ RD 
-WR to —RD Dela for No Reset 
30 
48 
TWRES 
-WR and —RD Comcldent Low for Reset 
250 
49 
rc 
Val|d Access Recovery Tlme 
6TcPC 
+200) 


—* 
IO 
I’\) O 
U1 
U1 O 
C) 
C) 
180 
120 


O 
100 
250 


3'583w- -v'U 
@U'I 
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Read and Wrlte Tlmlng Notes: 
1. Units are in nanoseconds. 
2. Parameter does not apply to Interrupt Acknowledge transactions. 
3. Float delay is defined as the time required for a 2t 0.5 V change at the output with a maximum dc load and minimum ac load. 
4. Parameter applies only between transactions involving the ESCC. 
5. Open-drain output, measured with open-drain test load. 
6. Parameter is system-dependent. For any ESCC in the daisy chain, TdlAi(RD) must be greater than the sum of TdPC (IEO) for 
the highest priority device in the daisy chain, TslEI(RDA) for the ESCC, and TdlEli(lEO) for each device separating them in the 
daisy chain. 


FIGURE 35. INTERRUPT ACKNOWLEDGE TIMING (SEE TABLE 1) 
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FIGURE 36. GENERAL TIMING (SEE TABLE 2) 
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TABLE 2. GENERAL TIMING 


No. 
Symbol 
Parameter 
— 
@ News 
1 
PCLK to -W/-REQ Valid Dela 
:- 
C REQ 
2 
C W 
PCLK to Wait Inactive Dela 
-8 
3 
Ts RXC(PC) 
-RxC to PCLK Setup Time 
2,5 
PCLK + 4 Case Onl 
RXD RXCr 
RxD to -RxC Setu Time X1 Mode 
_— 
2 
hRXD RXCr 
RXD to —RxC Hold Time X1 Mode 
— 
2 
RXD RXCI 
RxD to -RxC Setu Time X1 Mode 
j 
2 6 
RXD RXCI 
RxD to -RxC Hold Tlme x1 Mode 
150 
I 
2,6 
4 2 
SY nxc 
-SYNC to —RxC Setu Time 
j 
ThSY(RXC) 
-SYNC to —RxC Hold Time 
3Tc 
- 
4.2 
(OQ 
\I 
O) 
U1-> 


T 
'U 


OJ 


Q\IQO 
+200 
10 
TsTXC PC 
-TxC to PCLK Setu T'ime 
3 5 
11 
TdTXCt TXD 
-TxC to TxD Dela 
X1 Mode 
230 
3 
12 
TdTXCr TXD 
-TxC to TxD Dela 
X1 Mode 
230 
3,5 
13 
TdTXD TRX 
TxD to -TRxC Dela 
Send Clk Echo 
14 
RTXh 
-RTxC Hi h Width 
180 
15 
TwRTXl 
-RTxC Low Width 
16 
TcRTX 
-RTxC C cle Time 
400 
17 
TcRTXX 
C stal Oscillator Period 
000 
1000 
3 
18 
TwTRXh 
-TRxC Hih Width 
4 7 
19 
TwTRXl 
-TRXC Low Width 
4 7 
20 
TcTRX 
-TRxC C cle Time 
4 7 
21 
TwEXT 
—DCD or —CTS Pulse Width 
-SYNC Pulse Width 
22 
TwSY 


TABLE 3. SYSTEM TIMING 


Parameter 


O1:> 
coro-~Z 


.° 


-i 


ID 


o 


Z 


(QN\l\I 
\I 


OI98 


XC REQ 
—RxC to -W/—REQ Valid Dela 
12 
2 
RXC W 
—RxC to Wait Inactive Dela 
12 
1 2 
RXC SY 
—RxC to -SYNC Valid Dela 
7 
7 
2 
RXC INT 
—RxC to -INT Valid Dela 
dTXC REQ 
-TxC to -W/—REQ Valid Dela 
TXC W 
-TxC to Wait Inactive Dela 
TXC DRQ 
-TxC to -DTR/—R EQ Valid Dela 
4 
7 
4 
7 
TXC INT 
-TxC to —lNT Valid Dela 
SY INT 
-SYNC to -INT Valid Dela 
2 
TdEXT IN 
—DCD or —CTS to —lNT Valid Dela 
—*tOCO\lO>o 


—L—L 


--~oooor.o 


General and System Tlmlng Notes: 
1. Open-draln output, measured with open-drain test load. 
2. RxC is RTxC or TRxC, whichever is supplying the transmit clock. 
3. TxC is TFIxC or RTxC, whichever is supplying the transmit clock. 
4. Both TrxC and SYNC have 30 pF capacitors connected to ground. 
5. Applies only il the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and 
PCLK or TxC and PCLK is required. 
6. Applies only to FM encoding/decoding. 
7. Applies only for transmitter and receiver; DPLL and baud rate generator timing are identical to chip PCLK requirements. 
8. Units are in nanoseconds (ns). 
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FIGURE 37. SYSTEM TIMING (SEE TABLE 3) 
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ABSOLUTE MAXIMUM RATINGS 
Stresses above those listed under 
“Absolute Maximum Ratings‘ may 
Voltages on all pins 
-0.3V to 7.0V 
with respect to GND 


Operating Ambient 
0°C to +70°C 
Temperature 


Storage Temperature -65°C to +150°C 


STANDARD TEST 
CONDITIONS 
The d_c characteristics and capacitance 
section below apply for the following 
standard test conditions, unless other- 
wise noted. All voltages are referenced 
to GND. Positive current flows into the 
referenced pin. 


Standard conditions are as follows: 
' +4.75 V s Vcc s +5.25 V 
' GND = 0 V 
' TA as shown in Ordering Information 


cause permanent damage to the 
device. These are stress ratings only. 
Functional operation of this device at 
these or any other conditions above 


5V 


100 pF 


2.1 k 


those listed on the operational sections 
of this specification is not implied and 
exposure to absolute maximum ratings 
conditions for extended periods may 
affect device reliability. 


5V 


2.2 kQ 


FROM OUTPUT 
250 uA 
UNDER TEST I 50 pF 


DC CHARACTERISTICS: vcc = 5 vi 5%, TA = osc to 70°C 


Symbol 
Parameter 


VIH 
Input High Voltage 
VCC + 0 3 


VIL 
In ut Low Volta e 


VOH 


VOL 


I“4:- 


> 


Condltlons 
i 
P 
9 


Ouput High Voltage 
IOH = -250 uA 


Out ut Low Volta e 
V 
IOH = +2.0 mA 
P 
9 


IIL 
Input Leakage 
:i;10 0 
0.4 V 5 VIN 5 +2.4 V 


IOL 
Out ut Leaka e 
i10.0 
A 
0.4 V 5 VIN s +2.4 V 
P 
9 
I1 


ICC 
VCC Supply Current 
Clock Frequency == 8 MHz 


CAPACITANCE: TA = o<>c to 7o<>c, r = 1 MHz 


Symbol 
Parameter 
mmm 


Input Capacitance 
Unused Inputs Grounded 
Q2 


COU 
Output Capacitance 


Cl/O 
Bidirectional Capacitance 
Unused Inputs Grounded 
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ENHANCED SERIAL COMMUNICATIONS CONTROLLER (ESCC) 
FEATURES 
DESCRIPTION 
- Enhanced SCC functions support 
The VL85C3O CMOS Enhanced Serial 
DMA 
Communications Controller (ESCC) is a 


-—- 14-bit byte counter 
dual-channel, multi-protocol data 


-—- 19-bit-wide FIFO 
communications peripheral designed 


- 
for use with non-multiplexed buses. 
- Completely downward compatible 
. 
with the NMOS 8530 
The ESCC can be software configured 
for a wide variety of serial communica- 
' TWP idepedeni iUI|'dUP|9X Channels 
tions applications. The device contains 


- Programmable ¢|Q¢k factor 
a variety of new,’ sophisticated internal 
functions, including all of the features of 
- Break generation and error detection 
the NMQS 3530_ |n addition‘ the 
. |me||;gem SDLC/HDLC 
VL85C3O Enhanced SCC contains a 10 
x 19-bit FIFO array and 14-bit byte 
° L°°a' |°°pba°k and a“t° °°h° m°de$ 
counter. These features, in addition to 


- Internal or external character 
the "PIN _hI9h9' °I°°k II’9qU9"°Y 
synghfonizagn 
capabilities, allow the ESSC to be used 


- Low power consuming CMOS 
with a direct memory access (DMA) 
controller. 


The ESCC handles asynchronous for- 
mats, such synchronous byte-oriented 
protocols as IBM Bisync and such 
synchronous bit-oriented protocols as 
HDLC and IBM SDLC. This versatile 
device supports virtually any 
serial data transfer application (cas- 
sette, diskette, tape drives, etc.), 
including DMA. 


The device can generate and check 
CRC codes in any synchronous mode 
and can be programmed to check data 
integrity in various modes. The ESCC 
also has facilities for modem controls in 
both channels, in addition to its Byte - 
Counting Register and FIFO in SDLC 
mode. 


PIN DIAGRAM 
BLOCK DIAG RAM 


01 
cs 
cs 
07 
INT 
E0 
IE1 
-4NTACK 
vcc 
-W/-REQA 
-SYNCA 
—RTXCA 
RXDA 
-TRXCA 
TXDA 
-DTR/-REQA 
-RTSA 
—CTSA 
—DCDA 
PCLK 


VL85C3O 


1 
40 I D0 
2 
39 I 
D2 
3 
33 I 
D4 


4 
37 I 
D6 


5 
36 I -RD 
6 
35 I -WR 
7 
34 I 
AH3 
3 
33 I -CE 
9 
32 I D/-C 


10 
31 I GND 


1o DEEP 
STAT 
BYTE 
gg 
mo h couu 
GEN 
count 
REG 
A 
FIFO 


INT 
-<>~1 
LOGIC 


com i 


DATA 
a 


CPU 
I 
Q‘ 
, 
: 
S 
BUS V 


11 
30 I -W/-REQB 
‘NT 
‘NT 
cue 


12 
29 I -SYNCB 


13 
28 I -RTXCB 
14 
27 I 
RXDB 


15 
26 I 
--TRXCB 
16 
25 I TXDB 


com 
com 
- 
LINES ‘—Looic 
REG 


1o DEEP 
STATUS 
gm; 
BAUD 
RATE 
AND 
Q couu 
GEN 
17 
24 I -DTR/-REOB 
Cggy 
Risa = 
8 
18 
23 I 
—RTSB 
19 
22 I -CTSB 
20 
21 I -ocoe 
ORDER INFORMATION 
Part 
Clock 
Number 
¢ 


I‘ CHAEINEL 


SERIAL DATA 


CHANNEL ‘LT CHANNEL CLOCKS 
.1 
A 
4-5 -SYNC 
-WAIT/-REQUEST 


DISCRETE 4— 
CONTROL 
Q-— 
MODEMDMK OR 
AND STATU - -—> 
OTHER CONTROLS 
A 
1-P 


DISCRETE 
CONTROL 4—- 
MODEM.DMA. OR 
AND SJATU ‘ 
OTHER CONTROLS 


SERIAL DATA 


CHANNEL CLOCKS 
-SYNC 
—WAIT/-REOUEST 


Package 
Frequen y 
VL85C30-8PC 
Plastic DIP 
VL85C30-8OC 
Plastic _Leaded Chip Carrier (PLCC) 
VL35Q30-890 
Ceramic DIP 
VL85C30-10PC 
Plastic DIP 
VL85C30-10OC 
10 MHz 
Plastic Leaded Chip Carrier (PLCC) 
VL85C30-10CC 
Ceramic DIP 
VL85C30-12PC 
Plastic DIP 
VL85C30-12QC 
12 MHZ 
Plastic Leaded Chip Carrier (PLCC) 
VL85C30-12CC 
Ceramic DIP 
Note: Operating temperature range is 0°C to +70°C. 
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PIN DIAGRAM 
Do 
D4 
_ 


===i-.El—3 E8 B-8 E9 =_ $8 gi E8 E—e E32 


I3 


IEO 
A/-B 


IEI g 
-CE 


—INTACK E] 
o/-c 
vcc [E 
N.C. 


-W/—REOA [[1 
owo 
-SYNCA [E 
-W/-REOB 


—RTXCA [E 
-SYNCB 


RXDA ii} 
-RTXCB 
-TRXCA [E 
RXDB 


TXDA [=3 
-TRXCB 


N.C. ii 
Q TXDB 


IE IE El BI E Q El E E1 
E? 
N.C. -RTSA 
CDA-cope —RTSB 
N.C. 


-DTR/-REOA 
—CTSA PCLK -CTSB -DTRREOB 


SIGNAL DESCRIPTIONS 


Slgnal 
DIP Pln 
Slgnal 
Name 
Number 
Descrlptlon 


A/-B 
34 
Channel A/Channel B Select - This input signal selects the channel on which the read or 
write operation occurs. 
-CE 
33 
Chip Enable - This active low input signal selects the ESCC for a read or write operation. 


—CTSA, 
18, 
Clear To Send - Active low inputs - If these pins are programmed as auto enables, a low on 
-CTSB 
22 
the inputs enables the respective transmitters. If not programmed as auto enables, they may 
be used as general-purpose inputs. Both inputs are Schmitt trigger buffered to accommo- 
date slow rise time inputs. The ESCC detects pulses on these inputs and can interrupt the 
CPU on both logic level transitions. 


D/-C' 
32 
Data/Control Select - This input signal defines the type of information transferred to or from 
the ESCC. A HIGH means data is transferred; a low indicates a command. 


—DCDA, 
19 
Data Carrier Detect - Active low inputs - These pins function as receiver enables if they are 
—DCDB 
21 
programmed for auto enables; otherwise, they may be used as general-purpose input pins. 
Both pins are Schmitt trigger buffered to accomodate slow rise time signals. The ESCC 
detects pulses on these pins and can interrupt the CPU on both logic level transitions. 


D0-D7 
40,1,39,2,38, 
Data Bus - These bidirectional, three-state lines carry data and commands to and from the 
ESCC. 


-DTR/-REOA 
16, 
Data Terminal Ready/Request - These active low outputs follow the state programmed into 
-DTR/-REOB 
24 
the -DTR bit. They can also be used as general-purpose outputs or as request lines for a 
direct memeory access (DMA) controller. 


IEI 
7 
Interrupt Enable In - Active high output - IEI is used with IEO to form an interrupt daisy chain 
when there is more than one interrupt-driven device. A high IEI indicates that no other higher 
priority device has an interrupt underservice or is requesting an interrupt. 


IEO 
6 
Interrupt Enable Out - Active high output - IEO is high only if IEI is high and the CPU is not 
servicing an ESCC interrupt or the SCC is not requesting an interrupt (Interrupt Acknowledge 
cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits 
interrupts from lower priority devices. 
-INT 
5 
Interrupt Request - Active low open-drain output - This signal is activated when the ESCC 
requests an interrupt. 
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SIGNAL DESCRIPTIONS (Cont.) 


Slgnal 
DIP Pln 
Slgnal 
Name 
Number 
Descrlptlon 
_ 


—lNTACK 


PCLK 


—RD 
36 


RXDA, 
13, 
RXDB 


—RTXCA, 
12, 
-RTXCB 


-RTSA. 
IZ 
—RTSB 
23 


-SYNCA, 
1 1, 
-SYNCB 


TXDA, 
15, 
TXDB 
-TRXCA,’ 
14, 
—TRXCB 


—WR 
35 


—W/-RECIA 
—W/—RECIB 


I 
10! 


Interrupt Acknowledge - Active low input - This signal indicates an active Interrupt Acknowl- 
edge cycle. During this cycle, the ESCC interrupt daisy chain settles. When -RD be-comes 
active, the ESCC places an interrupt vector on the data bus (if IEI is high). The -INTACK 
signal is latched by the rising edge of PCLK. 


Clock - This input is the master ESCC clock used to synchronize internal signals. PCLK is a 
TTL level signal. 


Read - Active low input - This signal indicates a read operation and, when the ESCC is se- 
lected, enables the ESCC's bus drivers. During the Interrupt Acknowledge cycle, this signal 
gates the interrupt vector onto the bus if the ESCC is the highest priority device requesting an 
interrupt. 
. 


Receive Data - Active high inputs - These input signals receive serial data at standard TTL 
levels. 


Receive/Transmit Clocks - Active low inputs - These pins can be programmed in several 
different modes of operation. In each channel, -RTXC may supply the receive clock, the 
transmit clock, the clock for the baud rate generator, or the clock for the digital phase locked 
loop. These pins can also be programmed for use with the respective -SYNC pins as a 
crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in asynchro- 
nous modes. 


Request To Send - Active low outputs - When the —RTS bit in write register 5 (figure 7) is set, 
the —RTS signal goes low. When the -RTS bit is reset in the asynchronous mode and auto 
enable is on, the signal goes high after the transmitter is empty. In synchronous mode or in 
asynchronous mode with auto enable off, the -RTS pin strictly follows the state of the -RTS 
bit. Both pins can be used as general purpose outputs. 


Synchronization - Active low inputs or outputs - These pins can act either as inputs or outputs, 
or part of the crystal oscillator circuit. In the asynchronous receive mode (crystal oscillator 
option not selected), these pins are inputs similar to —CTS and —DCD. In this mode, transi- 
tions on these lines affect the state of the synchronous/hunt status bits in read register 0 
(Figure 6) but have no other function. 


In external synchronization mode with the crystal oscillator not selected, these lines also act 
as inputs. In this mode, -SYNC must be driven low to receive clock cycles after the last bit in 
the synchronous character is received. Character assembly begins on the rising edge of the 
receive clock immediately preceding the activation of -SYNC. 


In the internal synchronization mode (Monosync and Bisync) with the crystal oscillator not 
selected, these pins act as outputs and are active only during the part of the receive clock 
cycle in which synchronous characters are recognized. The synchronous condi-tion is not 
latched, so these outputs are active each time a synchronization pattern is recognized 
(regardless of character boundaries). In SDLC mode, these pins act as outputs and are valid 
on receipt of a flag. 


Transmit Data - Active high outputs - These output signals transmit serial data at standard 
TTL levels. 


Transmit/Receive Clocks - Active low inputs or outputs - These pins can be programmed in 
several different modes of operation. -TRXC may supply the receive clock or the transmit 
clock in the input mode or supply the output of the digital phase-locked loop, the crystal 
oscillator, the baud rate generator, or the transmit clock in the output mode. 


Write - Active low input - When the ESCC is selected, this signal indicates a write operation. 
The coincidence of —RD and -WR is interpreted as a reset. 


Wait/Request - Open-drain outputs when programmed for a wait function, driven high or low 
when programmed for a Request function - These dual-purpose outputs may be programmed 
as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the ESCC 
data rate. The reset state is Wait. 
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FUNCTIONAL 
DESCRIPTION 
The functional capabilities of the ESCC 
can be described from two different 
points of view. As a data communi- 
cations device, it transmits and receives 
data in a wide variety of data communi- 
cations protocols. As a microprocessor 
peripheral, the ESCC offers valuable 
features as vec-tored interrupts, polling, 
and simple handshake capability. 


DATA COMMUN|CA110NS 
CAPABILITY 
The ESCC provides two independent 
full-duplex channels programmable for 
use in any common asynchronous or 
syn-chronous data communication 
protocol. Figure 1 and the following 
description briefly detail these protocols. 


Asynchronous modes - Transmission 
and reception can be acwmplished 
independently on each channel with 5 
to 8-bits per character, plus optional 
even or odd parity. The transmitters 
can supply 1, 1 1/2, or 2 stop bits per 
character and a break output at any 
time. The receiver break-detection logic 
interrupts the CPU both at the start and 
at the end of a received break. 
Reception is protected from spikes by a 
transient spike-rejection mechanism 
that checks the signal one-half a bit 
time after a low level is detected on the 
receive data input (RXDA or RXDB). If 
the low does not persist (as in the case 
of a transient), the character assembly 
process does not start. 


Framing errors and overrun errors are 
detected and buffered together with the 
partial character on which they occur. 
Vectored interrupts allow fast servicing 
or error conditions using dedicated 
routines. Furthermore, a built-in 
checking process avoids the interpreta- 
tion of a framing error as a new start bit: 
a framing error results in the addition of 
one-half a bit time to the point at which 
the search for the next start bit begins. 


The ESCC does not require symmetric 
transmit and receive clock signals 
a feature allowing use of the wide vari- 
ety of clock sources. The transmitter 
and receiver can handle data at a rate 
of 1, 1/16, 1/32, or 1/64 of the clock rate 
supplied to the receive and transmit 
clock inputs. In asynchronous modes, 


the -SYNC pin may be pro-grammed as 
an input used for such functions as 
monitoring a ring indicator. 


Synchronous modes. The ESCC 
supports both byte-oriented and bit- 
oriented synchronous communication. 
Synchronous byte-oriented protocols 
can be handled in several modes, al- 
lowing character synchronization with a 
6-bit or 8-bit synchronous character 
(Monosync) any 12-bit synchroni-zation 
pattern (Bisync), or with an external 
synchronous signal. Leading sync 
characters can be removed without 
interrupting the CPU. 


5- or 7-bit synchronous characters are 
detected with 8- or 16-bit patterns in the 
ESCC by overlapping the larger pattern 
across multple incoming synchronous 
characters. 


The CRC checking for synchronous 
byte-oriented modes is delayed by one 
character time so that the CPU may 
disable CRC checking on specific 
characters. This allows the Imple- 
mentation of IBM Bisync. protocols. 


Both CRC-16 (X" + X" +X' + 1) and 
CCITT (X" + X" + X‘+ 1) error checking 
polynomials are supported. Either 
polynomial may be selected in all 
Synchronous modes. Users may preset 
the CRC generator and checker to all 
ones or all zeros. The ESCC also pro- 
vides a feature that automatically 
transmits CRC data when no other data 
is available for transmission. This 
allows for high-speed transmissions 
under DMA control, with no need for 
CPU intervention at the end of a mes- 
sage. When there is no data or CRC to 
send in synchronous modes, the 
transmitter inserts 6-, 8-, or 16-bit 
synchronous characters, regardless of 
the programmed character length. 


The ESCC supports synchronous bit- 
oriented protocols, such as SDLC and 
HDLC, by performing automatic flag 
sending, zero insertion, and CRC gen- 
eration. A special command can be 
used to abort a frame in transmission. 
At the end of a message, the ESCC 
automatically transmits the CRC and 
trailing flag when the transmitter un- 
derruns. The transmitter may also be 
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programmed to send an idle line con- 
sisting of continuous flag characters or 
a steady marking condition. 


If a transmit underrun occurs in the 
middle of a message, an external/sta- 
tus interrupt warns the CPU of this 
status change so that an abort may be 
issued. The ESCC may also be pro- 
grammed to send an abort itself in case 
of an underrun, relieving the CPU of this 
task. One to eight bits per character 
can be sent, allowing recep-tion of a 
message with no prior infor-mation 
about the character structure in the 
information field of a frame. 


The receiver automatically acquires 
synchronization on the leading flag of a 
frame in SDLC or HDLC and provides a 
synchronization signal on the -SYNC 
pin (an interrupt can also be pro- 
grammed). The receiver can be 
programmed to search for frames 
addressed by a single byte (or four bits 
within a byte) of a user-selected 
address or to a global broadcast 
address. In this mode, frames not 
matching either the user-selected or 
broadcast address are ignored. The 
number of address bytes can be 
extended under software control. For 
receiving data, an interrupt on the first 
received character, or an interrupt on 
every character, or on special con-dition 
only (end-of-frame) can be selected. 
The receiver automatically deletes all 
zeros inserted by the transmitter during 
character assembly. The CRC is also 
calculated and is automatically checked 
to validate frame transmission. At the 
end of transmission, the status of a 
received frame is availabe in the status 
registers. In SDLC mode, the ESCC 
must be programmed to use the SDLC 
CRC polynomial, but the generator and 
checker may be preset to all ones or all 
zeros. 


The CRC is inverted before transmis- 
sion and the receiver checks against 
the bit pattern 0001110100001111. 


The NR2, NRZI, or FM coding may be 
used in any 1x mode. The parity 
options available in asynchronous 
modes are available in synchronous 
modes. 
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The ESCC can be conveniently used 
under DMA control to provide high- 
speed reception or transmission. In 
reception, for example, the ESCC can 


FIGURE 1. ESCC PROTOCOLS 
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interrupt the CPU when the first 
character of a message is received 
The CPU then enables the DMA to 
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transfer the message to memory. The 
ESCC then issues an end-of-frame 
interrupt and the CPU can check the 
status of the received messsage. 
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The CPU is thereby freed for other 
service while the message is being 
received. The CPU may also enable 
the DMA first and have the ESCC in- 
terrupt only on end-of-frame. This 
procedure allows all data to be trans- 
ferred via the DMA. 


SDLC LOOP MODE 
The ESCC supports SDLC loop mode 
in addition to normal SDLC. In an 
SDLC loop, there is a primary control- 
ler station that manages the message 
traffic flow on the loop and any number 
of secondary stations. In SDLC loop 
mode, the ESCC performs the func- 
tions of a secondary station while an 
ESCC operating in regular SDLC mode 
can act as a controller (Figure 3). 


A secondary station in an SDLC Loop 
is always listening to the messages 
being sent around the loop, and in fact 
must pass these messages to the rest 
of the loop by retransmitting them with 
a one-bit time delay. The secondary 
station can place its own message on 
the loop only at specific times. The 
controller signals that secondary sta- 
tions may transmit messages by 
sending a special character, called an 
End Of Poll (EOP), around the loop. 
The EOP character is the bit pattern 
11 111110. Because of zero insertion 
during messages, this bit pattern is 
unique and easily recognized. 
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When a secondary station has a mes- 
sage to transmit and recognizes an 
EOP on the line, it changes the last 
binary 1 of the EOP to a 0 before 
trans-mission. This has the effect of 
turning the EOP into a flag sequence. 
The secondary station now places its 
message on the loop and terminates 
the message with an EOP. Any sec- 
ondary stations, further down the loop 
with messages to transmit, can then 
append their messages to the 
message of the first secondary station 
without messages to send. The 
following stations merely echo the 
incoming messages and are prohib- 
ited from placing messages on the 
loop (except upon recognizing an 
EOP). The SDLC loop mode is a 
programmable option in the ESCC; 
NR2, NRZI, and FM coding may all be 
used in SDLC Loop mode. 


BAUD RATE GENERATOR 
Each channel in the ESCC contains a 
programmable baud rate generator. 
Each generator consists of two 8-bit 
time constant registers that form a 16- 
bit time-constant, a 16-bit down 
counter, and a flip-flop on the output 
producing a square wave. On startup, 
the flip-flop on the output is set in a 
HIGH state, the value in the time- 
constant register is loaded into the 
counter, and the counter starts count- 
ing down. The output of the baud rate 
generator toggles upon reaching 0, 
the value in the time-constant register 
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process is repeated. The time constant 
may be changed at any time, but the 
new value does not take effect until the 
next load of the counter. 


The output of the baud rate generator 
may be used as either the transmit 
clock, the receive clock, or both. It can 
also drive the digital phase-locked loop 
(see next section). 


If the receive clock or transmit clock is 
not programmed to come from the 
-TRxC pin, the output of the baud rate 
generator may be echoed out via the 
-TRxC pin. 


The following formula relates the time 
constant to the baud rate (the baud rate 
is in bits/second and BR clock period is 
in seconds): 
baud rate = 


1 


2 (time constant+2) x (BR clock period) 


DIGITAL PHASE-LOCKED LOOP 
The ESCC contains a digital phase- 
locked-loop (DPLL) to recover clock 
information from a data stream with 
NRZI or FM encoding. The DPLL is 
driven by a clock that is nominally 32 
(NRZI) or 16 (FM) times the data rate. 
The DPLL uses this clock, along with 
the data stream, to construct a clock 
for the data. This clock may then be 
used as the ESCC receive clock, the 
transmit clock, or both. 


FIGURE 2. DETECTING 5- OR 7-BIT 
FIGURE 3. AN SDLC LOOP 
SYNCHRONOUS CHARACTERS 
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For NRZI encoding, the DPLL counts 
the 32x clock to create nominal bit 
times. As the 32x clock is counted, the 
DPLL is searching the incoming data 
stream for edges (either 1 to 0 or 0 to 
1). Whenever an edge is de-tected, the 
DPLL makes a count adjustment (during 
the next counting cycle), producing a 
terminal count closer to the center of the 
bit cell. 


For FM encoding, the DPLL still counts 
from 0 to 31, but with a cycle corres- 
ponding to two bit times. When the 
DPLL is locked, the clock edges in the 
data stream should occur between 
counts 15 and 16, and between counts 
31 and 0. The DPLL looks for edges 
only during a time centered on the 15 to 
16 counting transition. 


The 32x clock for the DPLL can be 
programmed to come from either the 
-RTxC input or the output of the baud 
rate generator. The DPLL output may 
be programmed to be echoed out of the 
ESCC via the -TRxC pin (if this pin is 
not being used as an input). 


DATA ENCODING 
The ESCC may be programmed to en- 
code and decode the serial data in four 
different ways (Figure 4). In NR2 en- 
coding, a 1 is represented by a HIGH 
level and a 0 is represented by a LOW 
level. In NRZI encoding, a 1 is repre- 
sented by no change in level and a 0 is 
represented by a change in level. 


In FM1 (more properly, bi-phase mark), 
a transition occurs at the beginning of 
every bit cell. A 1 is represented by 


an additional transition at the center of 
the bit cell and a 0 is represented by no 
additional transition at the center of the 
bit cell. In FMO (bi-phase space), a 
transition occurs at the beginning of 
every bit cell. A 0 is represented by an 
additional transition at the center of the 
bit cell, and a 1 is represented by no 
additional transition at the center of the 


bit cell. 


In addition to these four methods, the 
ESCC can be used to decode Manch- 
ester (bi-phase level) data by using the 
DPLL in the FM mode and program- 
ming the receiver for NR2 data. 
Manchester encoding always produces 
a transition at the center of the bit cell. 
If the transition is 0 to 1, the bit is a 0. If 
the transition is 1 to 0, the bit is a 1. 


AUTO ECHO AND LOCAL 
LOOPBACK 
The ESCC is capable of automatically 
echoing everything it receives. This 
feature is useful mainly in Asyn- 
chronous modes, but works in Syn- 
chronous and SDLC modes as well. In 
Auto Echo mode, TxD is RxD. Auto 
Echo mode can be used with NRZI or 
FM encoding with no additional delay, 
because the data stream is not de- 
coded before retransmission. ln Auto 
Echo mode, the —CTS input is ignored 
as a transmitter enable (although transi- 
tions on this input can still cause 
interrupts if programmed to do so). In 
this mode, the transmitter is actually 
bypassed and the pro-grammer is 
responsible for disabling transmitter 
interrupts and Wait/Request on trans- 
mit. 


The ESCC is also capable of local 
loopback. In this mode TxD is RxD, just 
as in auto echo mode. However, in 
local loopback mode, the internal 
transmit data is tied to the internal 
receive data and RxD is ignored (except 
to be echoed out via TxD). The -CTS 
and -DCD inputs are also ig-nored as 
transmit and receive enables. How- 
ever, transitions on these inputs can still 
cause interrupts. Local loopback works 
in asynchronous, synchronous, and 
SDLC modes with NRZ, NRZI, or FM 
coding of the data stream. 


I/O INTERFACE CAPABILITIES 
The ESCC offers the choice of polling, 
interrupt (vectored or nonvectored), and 
block transfer modes to transfer data, 
status, and control information to and 
from the CPU. The block transfer mode 
can be implemented under CPU or 
DMA control. 


POLLING 
All interrupts are disabled. Three status 
registers in the ESCC are auto-matically 
updated whenever any function is 
performed . For example, end-of-frame 
in SDLC mode sets a bit in one of these 
status registers. The idea behind 
polling is for the CPU to periodically 
read a status register until the register 
contents indicate the need for data to 
be transferred. Only one register needs 
to be read; depending on its contents, 
the CPU either writes data, reads data, 
or continues. Two bits in the register 
indicate the need for data transfer. 


FIGURE 4. DATA ENCODING METHODS 
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An alternative is a poll of the Interrupt 
Pending register to determine the 
source of an interrupt. The status for 
both channels resides in one register. 


INTERRUPTS 
When an ESCC responds to an Interrupt 
Acknowledge signal (-INTACK) from the 
CPU, an interrupt vector may be placed 
on the data bus. This vector is written in 
Write Register 2 (WR2) and may be 
read in Read Register 2A (RR2A) or 
Read Register 2B (RR2B) (Figures 8). 


To speed interrupt response time, the 
ESCC can modify three bits in this 
vector to indicate status. If the vector is 
read in Channel A, status is never 
included; if it is read in Channel B, 
status is always included. 


Each of the six sources of interrupts in 
the ESCC (Transmit, Receive, and 
External/Status interrupts in both 
channels) has three bits associated with 
the interrupt source: Interrupt Pending 
(IP), Interrupt Under Service (IUS), and 
Interrupt Enable (IE). Operation of the 
IE bit is straightforward. If the IE bit is 
set for a given interrupt source, that 
source can request interrupts. The 
exception is when the MIE (Master 
Interrupt Enable) bit in WR9 is reset and 
no interrupts may be requested. The IE 
bits are write only. 


The other two bits are related to the 
interrupt priority chain (Figure 5). As a 
microprocessor peripheral, the ESCC 
may request an interrupt only when no 
higher priority device is requesting one; 
e.g., when IEI is high. If the device in 
question requests an interrupt, it pulls 


down —lNT. The CPU then responds 
with —lNTACK, and the interrupting 
device places the vector on the data 
bus. 


In the ESCC, the IP bit signals a-need 
for interrupt servicing. When an IP bit 
is 1 and the IEI input is high, the INT 
output is pulled low, requesting an 
interrupt. In the ESCC, if the IE bit is 
not set by enabling interrupts, then the 
IP for that source can never be set. 
The IP bits are readable in RR3A. 


The IUS bits signal that aninterrupt 
request is being serviced. If an IUS is 
set, all interrupt sources of lower 
. 
priority in the ESCC and external to the 
ESCC are prevented from requesting 
interrupts. The internal interrupt 
sources are inhibited by the state of the 
internal daisy chain, while lower priority 
devices are inhibited by the IEO output 
of the ESCC being pulled LOW and 
propagated to subsequent peripherals. 
An IUS bit is set during an interrupt ac- 
knowledge cycle if there are no higher 
priority devices requesting interrupts. 


There are three types of interrupts: 
transmit, receive, and external/status. 
Each interrupt type is enabled under 
program control with Channel A having 
higher priority than Channel B, and with 
receive, transmit, and external/status 
interrupts prioritized in that order within 
each channel. When the transmit 
interrupt is enabled, the CPU is inter- 
rupted when the transmit buffer be- 
comes empty. (This implies that the 
transmitter must have had a data 
character written into it so that it can 
become empty.) When enabled, the 


receiver can interrupt the CPU in one of 
three ways: 


° 
On first receive character or special 
receive condition 


° 
On all receive characters or special 
receive condition 


° 
On special receive condition only. 


Interrupt on first character or special 
condition and interrupt on special 
condition only are typically used with 
the Block Transfer mode. A special 
receive condition is one of the following: 
receiver overrun, framing error in 
Asynchronous mode, end-of-frame in 
SDLC mode, and optionally, a parity 
error. The special receive condition 
interrupt is different from an ordinary 
receive character interrupt only in that 
the status is placed in the vector during 
the Interrupt Acknowledge cycle. In 
interrupt on first receive character, an 
interrupt can occur from special receive 
conditions any time after the first receive 
character interrupt. 


The main function of the external! 
status interrupt is to monitor the signal 
transitions of the —CTS,-CCD, and 
-SYNC pins; however, an external! 
status interrupt is also caused by a 
transmit underrun condition, or a zero 
count in the baud rate generator, or by 
the detection of a break (asynchronous 
mode), abort (SDLC mode) or EOP 
(SDLC loop mode) sequence in the data 
stream. 


FIGURE 5. INTERRUPT SCHEDULE 
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The interrupt caused by the abort or 
EOP has a special feature allowing the 
ESCC to interrupt when the abort or 
EOP sequence is detected or termi- 
nated. This feature facilitates the proper 
termination of the current message, 
correct initialization of the next mes- 
sage, and the accurate timing of the 
Abort condition in external logic in SDLC 
mode. In SDLC Loop mode, this feature 
allows secondary stations to recognize 
the need of the primary station to regain 


control of the loop during a poll se- 
quence. 


CPU/DMA BLOCK TRANSFER 
The ESCC provides a Block Transfer 
mode to accommodate CPU block 
transfer functions and DMA controllers. 
The Block Transfer mode uses the Waitl 
Request output in conjunction with the 
Wait/Request bits in WR1. The Wait! 
Request output can be defined under 
software control as a Wait line in the 


CPU Block Transfer mode or as a 
Request line in the DMA Block Transfer 
mode. 


To a DMA controller, the ESCC Request 
output indicates that the ESCC is ready 
to transfer data to or from memory. To 
the CPU, the Wait line indicates that the 
ESCC is not ready to transfer data, 
thereby requesting that the CPU extend 
the VO cycle. The DTR/Request line 
allows full-duplex operation under DMA 
control. 


PROGRAMMING 
The ESCC contains 13 write registers in 
each channel that are programmed by 
the system separately to configure the 
functional personality of the channels. 


In the ESCC, register addressing is 
direct for the data registers only, which 
are selected by a high on the D/-C pin. 
In all other cases (with the exception of 
WRO and RRO), programming the write 
registers requires two write operations 
and reading the read registers requires 
both a write and a read operation. The 
first write is to WRO and contains three 
bits that point to the selected register. 
The second write is the actual control 
word for the selected register, and if the 
second operation is read, the selected 
read register is accessed. All of the 
registers in the ESCC, including the data 
registers, may be accessed in this 
fashion. The pointer bits are auto- 
matically cleared after the read or write 
operation so that WRO (or RRO) is 
addressed again. 


TIMING 
The ESCC generates internal control 
signals from -WR and -RD that are 
related to PCLK. Since PCLK has no 
phase relationship with -WR and —RD, 
the circuitry generating these internal 
control signals must provide time for 
metastable conditions to disappear. 
This gives rise to a recovery time related 
to PCLK. The recovery time applies 
only between bus transactions involving 
the ESCC. The recovery time required 
for proper operation is specified from the 
rising edge of —WR or —RD in the first 
transaction involving the SCC, to the 
falling edge of WR or RD in the second 
transaction involving the ESCC. This 


The system program first issues a series 
of commands to initialize the basic mode 
of operation. This is followed by other 
commands to qualify conditions within 
the selected mode. For example, the 
asynchronous mode, character length, 
clock rate, number of stop bits, and even 
or odd parity might be set first. Then the 
interrupt mode would be set, and, finally, 
receiver or trans-mitter enable. 


READ REGISTERS 
The ESCC contains ten read registers 
(eleven counting receive buffer RR8) in 
each channel. Four of these may be 
read to obtain status information (RRO, 
RR1, RR10, and RR15). Two registers 
(RR12 and RR13) may be read to learn 
the baud rate generator time constant. 
The RR2 contains either the unmodified 
interrupt vector (Channel A) or the 
vector modified by status information 
(Channel B). Both RR7 and RR6 read 
the DMA FIFO. The RR3 contains the 
Interrupt Pending (IP) bits (Channel A). 


time must be at least four PCLK cycles 
plus 200 ns. 


READ CYCLE TIMING 
Figure 32 illustrates Read cycle timing. 
Addresses on A/-B and D/-C and the 
status on -INTACK must remain stable 
through the cycle. If -CE falls after -RD 
falls or if it rises before —RD rises, the 
effective -RD is shortened. 


WRITE CYCLE TIMING 
Figure 33 illustrates Write cycle timing. 
Addresses on A/-B and D/-C and the 
status on -INTACK must remain stable 
throughout the cycle. 
If —CE falls after 
—WR falls, or if it rises before —WR rises, 
the effective -WR is shortened. 


Figures 6 through 13 and Figure 31 
show the formats for each read register. 


The status bits of RRO and RR1 are 
carefully grouped to simplify status 
monitoring; 
e.g., when the interrupt 
vector indicates a special receive 
condition interrupt, all the appropriate 
error bits can be read from a single 
register (RR1). 


WRITE REGISTERS 
The ESCC contains 13 write registers 
(14 wunting WR8, the transmit buffer) in 
each channel. These write registers are 
programmed separately to configure the 
functional personality of the channels. 
In addition, there are two registers (WR2 
and WR9) shared by the two channels 
that may be accessed through either of 
them; WR2 contains the interrupt vector 
for both channels, while WR9 contains 
the interrupt control bits. Figures 14 
through 28 and Figure 31 show the 
format of each write register. 


INTERRUPT ACKNOWLEDGE CYCLE 
TIMING 
Figure 34 illustrates Interrupt Acknowl- 
edge cycle timing. Between the time 
-INTACK goes low and the falling edge 
of --RD, the internal and external IEI/IEO 
daisy chains settle. If there is an 
interrupt pending in the ESCC and IEI is 
high when -RD falls, the Acknowledge 
cycle is intended for the ESCC. In this 
case, the ESCC may be programmed to 
respond to —RD low by placing its 
interrupt vector on D0-D7 and it then 
internally sets the appropriate Interrupt- 
Under-Service latch. 
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FIFO DETAIL 
For a better understanding of details of 
the FIFO operation, referto the block 
diagram in Figure 39. 
ENABLE/DISABLE 
This FIFO is implemented so that it is 
only enabled when Channel A register 
WR15 bit 2 is set and the ESCC is in the 
SDLC/HDLC mode, otherwise the status 
register contents bypass the FIFO and 
go directly to the bus interface (the FIFO 
pointer logic is reset either when 
disabled or via a channel or power-on 
reset). When the FIFO mode is dis- 
abled, the ESCC is completely down- 
ward-compatible with the HMOS 
VL8530. The FIFO mode is disabled on 
power-up (WFI15 bit 2 is set to 0 on 
reset). The effects of backward com- 


FIFI4 is an image of RRO, RR5 is an 
image of RR1, RR6 is an image of RR2, 
and RR7 is an image of RR3. For 
details of the added registers, refer to 
Figure 3. The status of the FIFO Enable 
signal can be obtained by reading 
Channel A RR15 bit 2. If the FIFO is 
enabled, the bit will be set to 1; other- 
wise, it will be reset. Channel B WR15 
and RR15 behave exactly as in the 
VL8530 standard product. 


READ OPERATION 
When WR15 bit 2 is set and the FIFO is 
not empty, the next read to any of status 
register RR1 or the additional registers 
RR7 and RR6 will actually be from the 
FIFO. Reading status register RR1 
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causes one location of the FIFO to be 
emptied, so status should be read after 
reading the byte count, otherwise the 
count will be incorrect. Before the 
FIFO underflows, it is disabled. In this 
case, the multiplexer is switched to 
allow status to read directly from the 
status register, and reads from RR7 
and RR6 will contain bits that are 
undefined. Bit 6 of RR7 (FIFO Data 
Available) can be used to determine if 
status data is coming from the FIFO or 
directly from the status register, since it 
is set to one whenever the FIFO is not 
empty. 


Since not all status bits must be stored 
in the FIFO, the All Sent, Parity, and 
EOF bits will bypass the FIFO. The 
status bits sent through the FIFO will be 
Residue Bits (3), Overrun, and CRC 
Error. 


The sequence for proper operation of 
the byte count and FIFO logic is to read 
the registers in the following order: 
RR7, RR6, and RR1 (reading RR6 is 
optional). Additional logic prevents the 
FIFO from being emptied by multiple 
reads from RR1. The read from RR7 
latches the FIFO empty/full status bit 
(bit 6) and steers the status multiplexer 
to read from the ESCC megacell 
instead of the status FIFO (since the 
status FIFO is empty). The read from 
RR1 allows an entry to be read from the 
FIFO (if the FIFO was empty, logic is 
added to prevent a FIFO underflow 
condition). 
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WRITE OPERA11ON 
When the end of an SDLC frame (EOF) 
has been received and the FIFO is 
enabled, the contents of the status and 
byte-count registers are loaded into the 
FIFO. The EOF signal is used to 
increment the FIFO. If the FIFO 
overflows, the MSB of RR7 (FIFO 
Overflow) is set to Indicate the overflow. 
This bit and the FIFO control logic is 
reset by disabling and re-enabling the 
FIFO control bit (WFI15 bit 2). For 
details of FIFO control timing during an 
SDLC frame, refer to Figure 40. 
BYTE COUNTER DETAIL 
The 14-bit byte counter allows for 
packets up to 16K bytes to be received. 
For a better understanding of its 
operation, refer to Figures 39 and 40. 


ENABLE 
The byte counter is enabled in the 
SDLC/HDLC mode. 


RESET 
The byte counter is reset whenever an 
SDLC flag character is received. The 
reset is timed so that the contents of the 
byte counter are successfully written 
into the FIFO. 


INCREMENT 
The byte counter is incremented by 
writes to the data FIFO. The counter 
represents the number of bytes 
received by the ESCC, rather than the 
number of bytes transferred from the 
ESCC. (These counts may differ by up 
to the number of bytes in the receive 
data FIFO contained-in the ESCC.) 
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FIGURE 6. READ REGISTER O 
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FIGURE 14. WRITE REGISTER O 
FIGURE 17. WRITE REGISTER 3 
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FIGURE 22 
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FIGURE 29. ESCC STATUS REGISTER 
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FIGURE 30. SDLC BYTE COUN'I1NG DETAIL 
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FIGURE 31. ESCC REGISTERS 
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FIGURE 32. READ CYCLE TIMING 
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FIGURE 35. READ AND WRITE TIMING (SEE TABLE 1) 
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TABLE 1. READ AND WRITE TIMING CHARACTERISTICS: TA =o==c TO +1o=>c 


No. Symbol 
Parameter 


Q\l 
O‘) 
OIb(.0 
l'\)-4 
H 
H#HjHH 


—l 
-L 


OO 
O 
O 


wPCl 
PCLK Low Width 
PCh 
PCLK Hi h Width 
1000 
C 
PCLK Fall Time 
1 
C 
PCLK Rise Time 
PC 
PCLK C cle Time 
A WR 
Address to —WR Setu Time 
70 
WR 
Address to -WR Hold Time 
A RD 
Address to -RD Setu Time 
70 
9 
RD 
Address to —RD Hold Time 
10 
TslA PC 
-INTACK to PCLK Setu Time 
11 
TsIA| WR 
-INTACK to -WR Setu 
Time 
12 
ThlA WR 
-INTACK to -WR Hold Time 
13 
TslAi RD 
-INTACK to -RD Setu Time 
14 
TT1lA RD 
-INTACK to -RD Hold Time 
15 
ThlA PC 
-INTACK to PCLK Hold Time 
40 
16 
TsCE1 WR 
-CE Low to -WR Setu Time 
17 
ThCE WR 
-CE to —WR Hold Time 
18 
TsCEh WR 
-CE Hi h to —WR Setu Time 
19 
TsCE1 RD 
-CE Low to -RD Setu Time 
20 
ThCE RD 
-CE to —RD Hold 'l"ime 
21 
TsCEh RD 
-CE Hi h to —RD Setu Time 
22 
TwRD1 
—RD Low Width 
23 
TdRD DRA 
—RD to Read Data Active Dela 
24 
TdRDr DR 
-RD to Read Data Not Valid Dela 
25 
TdRDl DR 
—RD to Read Data Valid Dela 
14 
12 
26 
TdRD DRz 
—RD to Read Data Float Dela 
4 
3 
27 
TdA(DR) 
Address Required Valid to 


O 


145 


145 


roO1 


(J10 


Read Data Valid Dela 
28 
TwWR1 
-WR Low Width 
150 
29 
TsDW WR 
Write Data to -WR Setu Time 
30 
ThDW WR 
Write Data to —WR Hold Time 
31 
TdWR W 
—WR to Wait Valid Dela 
170 
16 
32 
TdRD W 
-RD to Wait Valid Dela 
170 
16 
33 
TdWRf REQ 
—WR to —W/—REQ Not Valid Dela 
170 
34 
TdRDl REQ 
—RD to --W/—REQ Not Valid Dela 
170 
16 
35 
TdWRr(REQ) 
-WR to -DTR/—REQ Not Valid Delay 
4TcPC 
TcP 


36 
TdRDr(REQ) 
—RD to -DTR/—REQ Not Valid Delay 
4TcP 
!l 


JsA 
OOo 
TcP 


37 
TdPC INT 
PCLK to -INT Valid Dela 
38 
TdlAi RD 
-INTACK to —RD Acknowlede Dela 
39 
TwRDA 
-RD Acknowlede Width 
40 
TdRDA DR 
-RD Ack 
to Read Data Valid Dela 
41 
TslEl RDA 
lElto -RD Acknowlede Setu Time 
42 
ThlEl RDA 
IEI to —RD Acknowlede Hold Time 
43 
TdlEl IEO 
lE|to IEO Dela Time 
44 
TdPC IEO 
PCLK to IEO Dela 
45 
TdRDA IN 
—RD to —lNT Inactive Dela 
46 
TdRD WRQ 
—RD to —WR Dela for No Reset 
47 
TdWRQ RD 
—WR to -RD Dela for No Reset 
48 
TwRES 
-WR and —RD Coincident Low for Reset 
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Read and Wrlte Tlmlng Notes: 
1. Units are in nanoseconds. 
2. Parameter does not apply to Interrupt Acknowledge transactions. 
3. Float delay is defined as the time requlred for a :i: 0.5 V change at the output with a maximum dc load and minimum ac load. 
4. Parameter applies only between transactions involving the ESCC. 
5. Open-drain output, measured with open-drain test load. 
6. Parameter is system-dependent. For any ESCC in the daisy chain, TdlAi(RD) must be greater than the sum of TdPC (IEO) for 
the highest priority device in the daisy chain, TslEl(RDA) for the ESCC, and TdlEll‘(lEO) tor each device separating them in the 
daisy chain. 


FIGURE 38. INTERRUPT ACKNOWLEDGE TIMING (SEE TABLE 1) 
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FIGURE 39. GENERAL TIMING (SEE TABLE 2) 
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TABLE 2. GENERAL TIMING 


No. 
Parameter 


otes 


oo\l 
ozui#- 


32sasasw 
22 


(D 
‘U 


Z 


1 
C REQ 
PCLK to -W/—REQ Valid Dela 
250 
2 
PC 
PCLK to Wait Inactive Dela 
3 
Ts RXC(PC) 
-RxC to PCLK Setup Time 
2,5 


' 
PCLK + 4 Case Onl 
RXD RXCr 
RxD to —RxC Setu Time X1 Mode 
2 
RXD RXCr 
RxD to —RxC Hold Time X1 Mode 
150 
2 
RXD RXCt 
RxD to -RxC Setu Time X1 Mode 
2 6 
RXD RXCt 
RxD to -RxC Hold Time X1 Mode 
2,6 
SY RXC 
-SYNC to -RxC Setu Time 
4 2 
9 
Y RXC 
-SYNC to -RxC Hold Time 
PC 
4 2 
10 
TsTXC PC 
-TxC to PCLK Setu 1'ime 
3 5 
11 
TXCI TXD 
-TxC to TxD Dela 
X1 Mode 
3 
12 
TdTXCr TXD 
-TxC to TxD Dela 
X1 Mode 
150 
3,5 
13 
TdTXD TRX 
TxD to -TRxC Dela 
Send Clk Echo 
200 
14 
TwRTXh 
-RTxC Hi h Width 
150 
15 
RTXI 
-RTxC Low Width 
150 
16 
TcRTX 
-RTxC C ole Time 
17 
TcRTXX 
C 
stal Oscillator Period 
125 
1000 
1000 
3 
18 
TwTRXh 
-TRxC Hi h Width 
150 
4,7 
19 
TwTRXl 
-TRxC Low Width 
150 
4 7 
20 
TRX 
-TRxC C cle Time 
4 7 
21 
EXT 
—DCD or -CTS Pulse Width 
200 
22 
-SYNC Pulse Width 


—~l—llio 


-L—L 
-A-A U101 
0101 oo 
oo 


\l\l\| 
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TABLE 3. SYSTEM TIMING 


No. 
Parameter 


OIOS 


XC REQ 
—RxC to -W/—REQ Valid Dela 
2 
RXC W 
-RxC to Wait Inactive Dela 
14 
1 2 
RXC SY 
—RxC to -SYNC Valid Dela 
7 
7 
2 
RXC INT 
—RxC to -INT Valid Dela 
10 
16 
TXC REQ 
-TxC to -W/—REQ Valid Dela 
5 
TXC W 
-TxC to Wait Inactive Dela 
11 
11 
TXC DRQ 
-TxC to -DTR/—REQ Valid Dela 
7 
7 
TXC INT 
-TxC to —INT Valid Dela 
10 
10 
SY INT 
-SYNC to -INT Valid Dela 
—DCD or -CTS to -INT Valid Dela 
-cooo\io:01-r--mix:-0 


?.'a*a‘a'a*a.'a_'?.'a' 


I1 


Z 


--moammm 
TdEXT IN 


General and System Tlmlng Notes: 
1. Open-drain output, measured with open-drain test load. 
2. RxC is RTxC or TRxC, whichever is supplying the transmit clock. 
3. TxC is TRxC or RTxC, whichever is supplying the transmit clock. 
4. Both TrxC and SYNC have 30 pF capacitors connected to ground. 
5. Applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and 
PCLK or TxC and PCLK is required. 
6. Applies only to FM encoding/decoding. 
7. Applies only for transmitter and receiver; DPLL and baud rate generator timing are identical to chip PCLK requirements. 
8. Units are in nanoseconds (ns). 
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FIGURE 40. SYSTEM _'I1MING (SEE TABLE 3) 
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ABSOLUTE MAXIMUM RATINGS 


VLSI TECHNOLOGY, INC. 
VL85C3O 


Voltages on all pins 
-0.3V to 7.0V 
Stresses above those listed under 
with respect to GND 
"Absolute Maximum Ratings" may 
Operating Ambient 
0,610 +70°C 
cause permanent damage to the 
Temperature 
device. These are stress ratings only. 
Functional operation of this device at 
Storage Temperature -65°C to +150°C 
these or any other conditions above 


STANDARD TEST 
CONDITIONS 
The dc characteristics and capacitance 
section below apply for the following 
standard test conditions, unless other- 
wise noted. All voltages are referenced 
to GND. Positive current flows into the 
referenced pin. 


Standard conditions are as follows: 
' +4.75 V 5 Vcc s +5.25 V- 


° GND =- O V 


° TA as shown in Ordering Information 


100 pF 


5V 


2.1kQ 


250 p.A 


those listed on the operational sections 
of this specification is not implied and 
exposure to absolute maximum ratings 
conditions for extended periods may 
affect device reliability. 


5V 


2.2 KQ 


FROM OUTPUT 
UNDER TEST l 50 pF 


DC CHARACTERISTICS: vcc = s v :I: 5%, TA = ooc to 1o<=c 


Symbol 
Parameter 
Condltlons 


I“ 


, 
A 


VIH 
Input High Voltage 
VCC + 0 3 


VIL 
Input Low Voltage 


VOH 


VOH 


Ouput High Voltage 
IOH = -1.0 mA 


Ouput High Voltage 
VCC O 8 
IOH = -250 |J.A 


VOL 
Output Low Voltage 
IOH = +2.0 mA 


> 
HI 
IIL 
Input Leakage 
:I:1OO 
O.4V£VlN$+2.4V 


IOL 
Output Leakage 
i10 0 
0.4 V s VIN s +2.4 V 
"I:I 


ICC 
VCC Supply Current 
35E 
See Note 


Note: Add 0.5 mA quiescent current to determine total maximum VCC supply current. (Example: at 10 MHz clock frequency, the 
total maximum VCC supply current equals 30 mA plus 0.5 mA or 30.5 mA.) 


CAPACITANCE: TA = o=c to 1o<>c, f = 1 MHZ 


Symbol 
Parameter 
Condltlons 


Q2 
Input Capacitance 
- 
Unused Inputs Grounded 


Cl/O 


COU 
Output Capacitance 


Bidirectional Capacitance 
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FEATURES 


~ 32-bit internal architecture 


- 32-bit external data bus 


- 64M-byte linear address space 


- Bus timing optimized for standard 
DRAM usage with page mode 
operation 


- 40M-byte/second bus bandwidth 


- Simple/powerful instruction set 
providing an excellent high level 
language compiler target 


~ Hardware support for virtual memory 
systems 


- Low interrupt latency for real-time 
application requirements 


- Full CMOS implementation results in 
low power consumption 


- Single 5 V i 5% operation 


- 84-pin JEDEC Type-B leadless chip 
carrier or plastic leaded chip carrier 
(PLCC) 


® VLSI TECHNOLOGY, mc. 
VL86C010 


32-BIT RISC MICROPROCESSOR 


DESCRIPTION 
The VL86C010 Acorn RISC Machine 
(ARM) is a full 32-bit general-purpose 
microprocessor designed using 
reduced instruction set computer 
(RISC) methodologies. The processor 
is targeted for the microcomputer, 
graphics, industrial and controller 
markets for use in stand-alone or 
embedded systems. Applications in 
which the processor is useful include 
laser printers, graphics engines, N.C. 
machines and any other systems 
requiring fast real-time response to 
external interrupt sources and high 
processing throughput. 


The VL86C010 features a 32-bit data 
bus, 27 registers of 32 bits each, a 
load-store architecture, a partially 
overlapping register set, 2.6 ps worst- 
case interrupt latency, conditional 
instruction execution, a 26-bit linear 
address space and an average 
instruction execution rate of from four- 
to-five million instructions per second 
(MIPS). Additionally, the processor 
supports two addressing modes: 
program counter (PC) and base 
register relative modes. The ability to 
do pre- and post-indexing allows 


stacks and queues to be easily 
implemented in software. All instruc- 
tions are 32 bits long (aligned on word 
boundaries), with register-to-register 
operations executing in one cycle. 
The two data types supported are 8-bit 
bytes and 32-bit words. 


Using a load-store architecture 
simplifies the execution unit of the 
processor, since only a few instruc- 
tions deal directly with memory and the 
rest operate register-to-register. Load 
and store multiple register instructions 
provide enhanced performance, 
making context switches faster and 
exploiting sequential memory access 
modes. 


The processsor supports two types of 
interrupts that differ in priority and 
register usage. The lowest latency is 
provided by the fast interrupt request 
(FIRQ) which is used primarily for I/O 
to peripheral devices. The other 
interrupt type (IRQ) is used for 
interrupt routines that do not demand 
low-latency service or where the 
overhead of a full context switch is 
small compared with the interrupt 
process execution time. 


PIN DIAGRAM 
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JEDEC TYPE-B CERAMIC LEADLESS CHIP CARRIER 
part 
mock 


“TRAN -FIRQABFIIREOPC Pl 
-B/W -CPI 09° 
P29 
PPA 
Number 
Frequency 
Package 


Plastic Leaded 
VL86C010-10QC 
10 MHZ 
Chip Carrier (PLCC) 


' 
JEDEC Type-B 
VL86C010-10LC 
Ceramic Carrier 


Plastic Leaded 
VL86C010-12QC 
Chip Carrier (PLCC) 


JEDEC Type-B 
VL86C010-12LC 
Ceramic Carrier 


Note: Operating temperature range is 0°C to +70°C 


PLEASE CONSULT RISC FAMILY DATA 
MANUAL FOR DETAILED INFORMATION 


® VLSI TECHNOLOGY, INC. 
VL86C110 


FEATURES 
' Drives up to 32 standard dynamic 
RAMs giving 4M bytes of real 
memory with 1M bit devices 


~ Logical-to-physical address 
translation (32M byte logical address 
space) supporting three protection 
levels: 
- Supervisor Mode 
- Operating System Mode 
- User Mode 
' Uses fast page mode DRAM 
accesses to maximize bandwidth 
from commodity memories 
' Internal DMA address generators for 
video, cursor and sound data buffers 


~ Various ROM speeds supported 
(access times of 450 ns, 325 ns, 
200 ns) 


v Provides all critical system timing 
Including processor clocks, --RAS, 
-CAS, and DMA data transfer strobes 


¢ Arbitrates memory between the 
processor and DMA systems 


RISC MEMORY CONTROLLER (MEMC) 


DESCRIPTION 
The memory controller (MEMC) acts as 
the interface between the ARM (Acorn 
RISC Machine) processor and other 
functions in the system. The four circuits 
in the RISC family: MEMC, ARM, 
VIDC-video controller, and IOC-I/O 
controller, can be used to implement a 
small computer system. MEMC uses a 
single clock input to derive timing 
information for the other components. 


In addition to providing interlace signals 
to the other controllers, MEMC gener- 
ates all the control signals for several 
access times of read-only memory 
(ROM) plus high-resolution timing and 
refresh control for dynamic RAM 
(DRAM). The controller outputs can 
drive up to 32 memory devices directly 
in a wide variety of configurations using 
various architectures of standard 
DRAMs. A logical-to-physical address 
translator maps the 4M byte physical 
memory into the 32M byte logical 
address space with three levels of 
protection. 


Address translation is performed by a 
simple 128 entry content-addressable 


memory (CAM). MEMC provides a 
descriptor entry for every page of 
physical memory which eliminates 
descriptor thrashing (address transla- 
tion misses) from degrading system 
performance. 


The simple structure allows memoiy 
address translation to be performed 
without increasing required memory 
access time or decreasing the system 
clock. MEMC allows virtual memory and 
multi-tasking operations to be imple- 
mented without the usual performance 
degradation associated with each 
function. Fast page mode DRAM 
accesses are used to maximize 
memory bandwidth from inexpensive 
commodity memoiy devices. 


MEMC supports direct memory access 
(DMA) read operations with three 
programmable address generators. 
Video refresh is performed using a 
circular buffer to enhance scrolling 
capability plus a separate linear buffer 
for a cursor sprite. Sound data uses a 
double buffering system. 


PIN DIAGRAM 
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Package 


Plastic Leaded 
Chip Carrier (PLCC) 


JEDEC Type-B 
Ceramic Carrier 


'oGT 
Note: Operating temperature range is 0°C to + 70°C. 
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PLEASE CONSULT RISC FAMILY DATA 
"7 " 's°R° 
MANUAL FOR DETAILED INFORMATION 
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FEATURES 
- Pixel rate selectable as 8, 12, 16, or 
24 MHz 


- Serializes data to 1-, 2-, 4-, or 8- bits 
per pixel 


~ 16 x 13 bit words - 4096 color lockup 
palette 


- Three 4-bit DACs (one for each CRT 
9"") 


- Fully programmable screen parame- 
ters 


- Screen border in any of the 4096 
possible colors 


- Flexible cursor sprite 


- Support for interlaced display format 


~ External synchronization capability 


- Very high resolution monochrome 
mode support 


- High quality stereo sound generation 


PIN DIAGRAM 
JEDEC TYPE-B CERAMIC LEADLESS 
CHIP CARRIER 
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RISC VIDEO CONTROLLER (VIDC) 


DESCRIPTION 
The Video Controller (VIDC) accepts 
video data from DRAM under DMA 
control, serializes and passes it through 
a color look-up palette, and converts it 
to analog signals for driving the CRT 
guns. The chip also controls all the 
display timing parameters plus the 
position and pattern of the cursor sprite. 
In addition, the VIDC includes an 
exponential DAC and stereo image 
table for the generation of high quality 
sound from_ data in the DRAM. 


The VIDC requests data from the RAM 
when required, and buffers it in one of 
three first-in, first-out memories 
(FlFOs). Note that the addressing of the 
data in RAM is controlled elsewhere in 
the system (usually in the VL86C110 
Memory Controller, MEMC). Data is 
requested in blocks of four 32-bit words, 
allowing efficient use of page-mode 
DRAM without locking up the system 
data bus for long periods. 


The VIDC is a highly programmable de- 
vice, offering a very wide choice of dis- 
play formats. The pixel rate can be se- 


lected in a range between 8 and 24 
MHz and the data can be serialized to 
either 8-, 4-, 2-, or 1-bit per pixel. The 
horizontal timing parameters can be 
controlled to units of 2 pixels, and the 
vertical timing parameters can be 
controlled in units of a raster. The color 
lookup palette which drives the three 
on-chip DACs is 13 bits wide, offering a 
choice from 4096 colors or an external 
video source. 


Extensive use is made of pipelining 
throughout the device. 


The cursor-sprite is 32 pixels wide, and 
any number of rasters high. Three 
simultaneous colors (from the 4096 
possible) are supported, and any pixel 
can be defined as transparent, making 
possible cursors of many shapes. The 
cursor can be positioned anywhere on 
the screen. 


The sound system implemented on the 
device can support up to eight chan- 
nels, each with a separate stereo 
position. 


ORDER INFORMATION 
Part 
Number 
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VL86C310-08QC 


VL86C310-08LC 


Note: Operating temperature is 0°C to +70°C. 


Clock 
Frequency 
Package 


Plastic Leaded 
Chip Carrier (PLCC) 


JEDEC Type-B 
Ceramic Carrier 


PLEASE CONSULT RISC FAMILY DATA 
MANUAL FOR DETAILED INFORMATION 
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FEATURES 
- Power on reset control 


- Four independent 16-bit program- 
mable counters 
-Two timers 
—Two baud rate generators 


- Bidirectional serial keyboard interface 


- Six programmable bidirectional 
control pins 


- Interrupt mask, request and status 
registers for -IRQ and —FlRQ 


~ 14 level triggered interrupt inputs 


- Two edge triggered interrupt inputs 


- Four programmable peripheral cycles 
— Slow 
- Medium 
- Fast 
- 2 MHz synchronous 


- Seven external peripheral selects 


- ARM/IO bus interface control 


- Expansion bus buffer control 


RISC I/O CONTROLLER (IOC) 


DESCRIPTION 
The VL86C410 Input/Output Controller 
(IOC) is designed to interlace to the 
VL86C010/VL86C110NL86C310 chip 
set to provide a unified view of inter- 
rupts and peripherals within an Acorn 
RISC Machine (ARM) based computer. 
It controls an 8-to-32 bit I/O data bus to 
which on-board peripherals and any VO 
expansions are connected. It provides a 
set of internal functions, which are 
accessed without wait states, and 
programmable speed access to external 
peripherals. 


The VL86C410 provides system level 
I/O with six programmable control pins 
and a full-duplex, bidirectional serial 
keyboard interface. To support system 
timing requirements, the VL86C410 
contains four independent program- 
mable counters. Two of these counters 
are used as baud rate generators. One 
is dedicated to the keyboard and the 
other controls the BAUD output pin to 


generate a free-running clock. The 
other two counters can be used to 
generate system timing events. 


The IOC serves as the interface 
between the very high-speed RISC 
system bus and the slower I/O or 
expansion bus. The part provides all the 
buffer control required between the two 
buses. The VL86C410 supports an 
interruptable I/O cycle thats allows the 
system to use slower, low-cost periph- 
eral controllers such as the VL16C450‘ 
Asynchronous Communications 
Element and VL1772 Floppy Disk 
Controller without severe latency on the 
system bus. 


Peripheral controllers are supported 
with 16 interrupt inputs (14 level 
sensitive and two edge-triggered), 
seven peripheral select outputs, and 
four programmable I/O cycle times. 
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VL86C410-08QC 


vcc 
VL86C410-08LC 


Package 


Plastic Leaded 
Chip Carrier (PLCC) 


JEDEC Type-B 
Ceramic Carrier 


8 MHz 


Note: Operating temperature is 0°C to +70°C. 


KIN 


-IRQ 
PLEASE CONSULT RISC FAMILY DATA 
;';'“° 
MANUAL FOR DETAILED INFORMATION 
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APPLICATION SPECIFIC LOGIC AND GOVERNMENT PRODUCTS 
VLSI Technolo 
Inc 
8375 South River Parkwa ' Tem e AZ 85284 
602 752 8574 


VLSI SALES OFFICES 
81 DESIGN CENTERS 


CALIFORNIA 
2235 Oume Dr. 
San Jose. CA 95131 
408-943-0264 
FAX 408-943-9792 
TELEX 278807 
MAIL 
1109 McKay Dr. 
. 
San Jose, CA 95131 
1751 E. Garry Ave., Ste. A 
Santa Ana, CA 92705 
714-250-4900 
FAX 714-250-9041 
FLORIDA 
2200 Park Central N., Ste. 600 
Pompano Beach, FL 33064 
305-9710404 
FAX 305-971-2088 
ILLINOIS 
1350 Remington Rd., Stes. A-D 
Schaumburg, IL 60195 
312-310-9595 
FAX 312-310-9632 
MASSACHUSETTS 
261 Ballardvale St. 
Wilmington, MA 01887 
617-658-9501 
FAX 617-657-6420 
NEW JERSEY 
101 Morgan Lane, Ste. 380 
Plalnsboro, NJ 08538 
609-799-5700 
FAX 609-799-5720 
TEXAS 
850 E. Arapaho Rd., Ste. 270 
Richardson, TX 75081 
214-231-6716 
FAX 214-669-1413 
FRANCE 
2, Allee du 10, Rue Ambroise 
Croizat 
F-91120 Palaiseau-France 
1-6447.04.79 
TELEX vlsifr 600 759 F 
FAX 1-6447.04.80 
GERMANY 
Rosenkavalierplatz 10 
0-8000 Munich 81 
West Germany 
0 89/92 69 05 0 
TELEX 521 4279 vlsid 
FAX 0 89-92690545 
JAPAN 
Shuwa-Kioicho Tbr. Blvd., Rm 816 
5-7 Kojimati, Chiyoda-Ku 
Tokyo, Japan 102 
81-3239-5211 
FAX 81-3-239-5215 
UNITED KINGDOM 
486-488 Midsummer Blvd. 
Saxon Gate West, Central 
Milton Keynes, MK9 2E0 
United Kingdom 
09 08/66 75 95 
TELEX vlsiuk 825 135 
FAX 09 08/67 00 27 


VLSI AUTHORIZED 
DESIGN CENTERS 


COLORADO 
SIS MICROELECTRONICS, INC. 
Longmont. 303-776-1667 
MAINE 
OUADIC SYSTEMS, INC. 
South Portland, 207-871-8244 


PENNSYLVANIA 
INTEGRATED CIRCUIT 
SYSTEMS, INC. 
King of Prussia. 215-265-8690 
IRELAND 
AXIOM ELECTRONICS LTD. 
High Wycombe Bucks 
04 94/46 16 16 
SWEDEN 
NORDISK ARRAYTEKNIK AB 
Solna, (oa) 734 ss as 


VLSI SALES OFFICES 


ALABAMA 
2614 Artie St., Ste. 36 
Huntsville, AL 35805 
205-539-5513 
FAX 205-536-8622 
ARIZONA 
8375 South River Parkway 
Tempe, AZ 85284 
602-752-6450 
FAX 602-752-6000 
CALIFORNIA 
225 W. Broadway, Ste. 500 
Glendale, CA 91204 
818995-2404 
CONNECTICUT 
60 Church St. 
Yalesville, CT 06492 
203-265-6698 
FAX 203-265-3653 
FLORIDA 
601 Cleveland St., Ste. 400 
Clearwater, FL 33515 
813-443-5797 
FAX 813-443-5674 
GEORGIA 
2400 Pleasant Hill Rd., Ste. 200 
Duluth, GA 30138 
404-476-8574 
FAX 404-476-3790 
MARYLAND 
P.O. Box 289 
124 Maryland, Rte. 3 N. 
Millersville. MD 21108 
301-987-8777 
FAX 301-987-8779 
MINNESOTA 
5871 Cedar Lake Rd., Ste. 9 
St. Louis Park, MN 55416 
612-545-1490 
FAX 612-545-3489 
NORTH CAROLINA 
2100 West Park 0r., Ste. 201 
Research Triangle Park, NC 27713 
919-544-1891/92 
FAX 919-361-1943 
OREGON 
10300 S.W. Greenburg Rd., Ste. 365 
Portland. OR 97223 
503-244-9882 
FAX 503-245-0375 


VLSI SALES 
REPRESENTATIVES 


ARIZONA 
SYSTEM SALES OF ARIZONA 
Tempe, 602-829-9338 
CALIFORNIA 
BESTRONICS 
San Diego, 619-693-1111 
EMERGING TECHNOLOGY 
San Jose, 408-433-9366 
EMERGING TECHNOLOGY 
Fairoaks, 916-962-3030 


COLORADO 
LUSCOMBE ENGINEERING 
Longmont, 303-772-3342 
' 
IOWA 
SELTEC SALES 
Cedar Rapids, 319-364-7660 
KANSAS 
SPECTRUM SALES 
Overland Park. 913-648-6811 
MISSOURI 
SPECTRUM SALES 
Hazelwood, 314-731-5151 
NEW MEXICO 
SYSTEM SALES OF ARIZONA 
Albuquerque, 505-242-7998 
NEW YORK 
bbd ELECTRONICS 
Rochester, 716-425-4101 
OHIO 
SAI MARKETING 
Columbus. 614-876-8650 


SAI MARKETING 
Dayton, 513-435-3181 
SAI MARKETING 
Shaker Heights, 216-751-3633 
OKLAHOMA 
LOGIC 1 SALES 
Tulsa, 918-494-0765 
OREGON 
MICRO SALES 
Beaverton, 503-645-2841 
TEXAS 
LOGIC 1 SALES 
Austin, 512-459-1297 


LOGIC 1 SALES 
Richardson, 214-2340765 
WASHINGTON 
MICRO SALES 
Bellevue, 206-451-0568 
AUSTRALIA 
ENERGY CONTROL 
Brisbane, 61 -7-3762955 
BELGIUM AND 
LUXEMBURG 
DIODE 
Bruxelles, (02) 21s 2100 
CANADA 
bbd ELECTRONICS 
Port Coquitlan, B.C. 
604-941-7707 
bbd ELECTRONICS 
Mississauga, Ontario 
416-821-7800 
bbd ELECTRONICS 
Ottawa, Ontario 
613-729-0023 
bbd ELECTRONICS 
Pointe Claire, Quebec 
514-697-0804 
HONG KONG 
LESTINA INTERNATIONAL, LTD. 
Kowloon, 3-7231736 
ISRAEL 
RDT ELECTRONICS 
ENGINEERING LTD. 
Tel-Aviv, (3) 48 32 11-9 
KOREA 
EASTERN ELECTRONICS 
Seoul. 82-02-464-0399 
SINGAPORE 
DYNAMIC SYSTEMS 
ELECTRONICS 
Singapore, 65-289-2024 
TAIWAN 
PRINCETON TECH 
Taipei, 886-2-717-1439 


VLSI DISTRIBUTORS 
(A) ARROW 
ELECTRONICS, INC. 
(s) SCHWEBER 
ELECTRONICS 
ALABAMA 
Huntsville, 205-aa7-sass (A) 
Huntsville, 205-8950480 (S) 
ARIZONA 
Phoenix, 602-968-1800 (A) 
Phoenix, 602-997-1874 (S) 
CALIFORNIA 
Canoga Park, 818-999-4702 (S) 
Gardena, 213-320-8090 (S) 
Irvine, 714-sssozoo (s) 
Los Angeles, 818-701-7500 (A) 
Orange County, 714-838-5422 (A) 
Sacramento, 916-929-9732 (S) 
San Diego, 619-565-4800 (A) 
San Diego, 619-450-0454 (s) 
San Francisco, 408-745-6600 (A) 
San Jose, 408-432-7171 (S) 
COLORADO 
Denver, 303-696-111 1 (A) 
Englewood, 303-799-0258 (S) 
CONNECTICUT 
Danbury. 203-748-7080 (s) 
Wallingford. 203-2ss-7741 (A) 
FLORIDA 
Altamonte Springs. 305-331-7555 (S) 
Clearwater, 813-576-8995 (A) 
Fort Lauderdale, 305-429-8200 (A) 
Melbourne, 305-725-1480 (A) 
Pompano Beach, 305-977-7511 (S) 
GEORGIA 
Atlanta, 404-449-8252 (A) 
Norcross, 404-449-4600 (S) 
ILLINOIS 
Chicago, 312-397-3440 (A) 
Elk Grove Village, 312-364-3750 (S) 
INDIANA 
Indianapolis. 317-243-9353 (A) 
IOWA 
Cedar Rapids, 319-ass-7230 (A) 
Cedar Rapids, 319-373-1417 (S) 
KANSAS 
Overland Park, 913-492-2922 (S) 
MARYLAND 
Baltimore, 301-995-6002 (A) 
Gaithersburg, 301-840-5900 (S) 
MASSACHUSETTS 
Bedford, 617-275-5100 (S) 
Boston, 617-933-8130 (A) 
MICHIGAN 
Detroit, 313-971-8220 (A) 
Grand Rapids, 616-243-0912 (A) 
Livonia, 313-525-8100 (S) 
MINNESOTA 
Edina, s12-941-szso (s) 
Minneapolis. 612-830-1800 (A) 
MISSOURI 
Earth City, 3147390526 is) 
st. Louis, 314-ss7-seas (A) 
NEW HAMPSHIRE 
Manchester, 603-668-6968 (A) 
Manchester, 603-625-2250 (S) 
NEW JERSEY 
Fairfield, 201-575-5300 (A) 
Fairfield, 201-227-7sao (s) 
Marlton, sos-ssssooo (A) 
NEW MEXICO 
Albuquerque, 505-243-4566 (A) 
NEW YORK 
Long Island, 516-231-1000 (A) 
Rochester, 716-427-0300 (A) 
Rochester, 716-424-2222 (S) 
Syracuse, 315-652-1000 (A) 
Westbury, 516-334-7474 (S) 


NORTH CAROLINA 
Raleigh, 919-876-3132 (A) 
Raleigh, 919-876-0000 (s) 
Winston-Salem, 919-725-8711 (A) 
OHIO 
Beachwood, 216-464-2970 (S) 
Cleveland, 216-248-3990 (A) 
Columbus, 614-885-8362 (A) 
Dayton, 513-435-5563 (A) 
Dayton, 513-439-1800 (S) 
OKLAHOMA 
Tulsa, 918-665-7700 (A) 
Tulsa, 918-622-8003 (s) 
OREGON 
Portland, 503-684-1690 (A) 
PENNSYLVANIA 
Horsham, 215-441-0600 (S) 
Philadelphia, 215-928-1800 (A) 
Pittsburgh, 412-856-7000 (A) 
Pittsburgh, 412-782-1600 (S) 
RHODE ISLAND 
East Providence, 401-431-0980 (A) 
TEXAS 
Austin, 512-835-4180 (A) 
Austin, 512-458-8253 (S) 
Dallas, 214-380-6464 (A) 
Dallas, 214-661-5010 (S) 
Houston, 713-530-4700 (A) 
Houston, 713-784-3600 (S) 
UTAH 
Salt Lake City, 801-972-0404 (A) 
WASHINGTON 
Seattle, 206-643-4800 (A) 
WISCONSIN 
Milwaukee, 414-792-0150 (A) 
New Berlin, 414-784-9020 (S) 
PU ERTO RICO 
San Juan, 809-723-6500 (A) 
CANADA 
Montreal, 514-735-5511 (A) 
Ottawa, 613-226-6903 (A) 
Quebec City, 418-687-4231 (A) 
Toronto, 416-661-0220 (A) 
FRANCE 
ASAP c.a. 
Montigny-le-Bretonneux, 
(1) 3043.82.33 
GERMANY 
DATA MODUL GmbH 
Munich, 0 89/5 60 17-0 
blt-electronic AG 
Munich. 0 89/4180 07 20 
SE SPEZIAL-ELECTRONIC KG 
Biickeburg, 0 5722/20 32 
JAPAN 
ASAHI GLASS co. LTD. 
Tokyo. er-s-210-sas4 . 


TEKSEL COMPANY, LTD. 
Tokyo, at-3461-sa11 
TOKYO auzcrnou, no 
Tokyo, 81423-33-8009 
KOREA 
EASTERN ELECTRONICS 
Seoul, 82-O2-464-0399 
NETHERLANDS 
DIODE 
Houten, (0 34 03) 912 34 
SOUTH AMERICA - BRAZIL 
INTERNATIONAL TRADE 
DEVELOPMENT 
Palo Alto, 415-856-6686 
SPAIN AND PORTUGAL 
SEMICONDUCTORES 0.1. 
Barcelona, (3) 217 23 40 
SWITZERLAND 
FABRIMEX AG 
Ziirich, (01)2 5129 29 


The information contained In this document has 
such Information, and this document does not in 
been carefully checked and ls believed to be 
any way extend VLSl's warranty on any product 
reliable; however, VLSI shall not be responsible for 
beyond that set forth in VLSl's standard terms and 
any loss or damage of whatever nature resulting 
conditions of sale. VLSI does not guarantee that 
from the use of, or reliance upon, the information 
the use of any information contained herein will not 
contained in this document. VLSI makes no 
infringe upon the patent or other rights of third 
guarantee or warranty concerning the accuracy of 
parties, and no patent or other license is implied 


hereby. VLSI reserves the right to make changes in 
the products without notication which would 
render the information contained in this document 
obsolete or inaccurate. Please contact VLSI for the 
latest information concerning these products. 
© 1988 VLSI Technology, Inc. Printed in U.S.A. 
8350-400100-001 
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VLSI Technology, Inc. 
Application Specific 
Logic Products Division 
8375 South River Parkway 
Tempe, AZ 85284 
602-752-8574 
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